All Projects → Zaid-Ajaj → SAFE.Simplified

Zaid-Ajaj / SAFE.Simplified

Licence: other
A lightweight alternative template of SAFE for happy cross-IDE full-stack F# development

Programming Languages

F#
602 projects
javascript
184084 projects - #8 most used programming language
HTML
75241 projects

Projects that are alternatives of or similar to SAFE.Simplified

Feliz.MaterialUI
Feliz-style Fable bindings for Material-UI
Stars: ✭ 57 (-41.24%)
Mutual labels:  fable, elmish, feliz
navigation-bar-with-feliz
Modern navigation bar built with Feliz
Stars: ✭ 20 (-79.38%)
Mutual labels:  fable, feliz
Fable.Lit
Write Fable Elmish apps with Lit
Stars: ✭ 64 (-34.02%)
Mutual labels:  fable, elmish
Feliz.MaterialUI.MaterialTable
Fable bindings written in the Feliz-style for material-table.
Stars: ✭ 17 (-82.47%)
Mutual labels:  fable, feliz
Feliz.Router
A router component for React and Elmish that is focused, powerful and extremely easy to use.
Stars: ✭ 66 (-31.96%)
Mutual labels:  fable, elmish
Feliz.ViewEngine
Feliz DSL and engine for HTML generation and server side rendering (SSR)
Stars: ✭ 53 (-45.36%)
Mutual labels:  fable, feliz
Feliz.Recoil
Fable bindings in Feliz style for Facebook's experimental state management library recoil.
Stars: ✭ 43 (-55.67%)
Mutual labels:  fable, feliz
Feliz.Bulma
Bulma UI (https://bulma.io) wrapper for amazing Feliz DSL
Stars: ✭ 57 (-41.24%)
Mutual labels:  fable, feliz
Feliz
A fresh retake of the React API in Fable and a collection of high-quality components to build React applications in F#, optimized for happiness
Stars: ✭ 273 (+181.44%)
Mutual labels:  fable, type-safe
FableStarter
An Elmish F# Fable template that uses Tailwind for styling and the Parcel bundler
Stars: ✭ 13 (-86.6%)
Mutual labels:  fable, elmish
elmish-getting-started
A simple and minimalistic template to easily get up and running with Elmish and Fable
Stars: ✭ 22 (-77.32%)
Mutual labels:  fable, elmish
Fable.remoting
Type-safe communication layer (RPC-style) for F# featuring Fable and .NET Apps
Stars: ✭ 175 (+80.41%)
Mutual labels:  fable, type-safe
raspberry-fsharp
F# full-stack IoT starter project for Raspberry Pi
Stars: ✭ 33 (-65.98%)
Mutual labels:  fable, elmish
Hemmelig.app
Keep your sensitive information out of chat logs, emails, and more with encrypted secrets.
Stars: ✭ 183 (+88.66%)
Mutual labels:  safe
typist-json
A simple runtime JSON type checker.
Stars: ✭ 25 (-74.23%)
Mutual labels:  type-safe
desafios-bootcamps-dio
Desafios em C#, Java, JavaScript, Kotlin, Python e Ruby dos Bootcamps da Digital Innovation One
Stars: ✭ 442 (+355.67%)
Mutual labels:  full-stack
routing
Aplus Framework Routing Library
Stars: ✭ 186 (+91.75%)
Mutual labels:  full-stack
SAFE-Stack.github.io
Website for Saturn + Azure + Fable + Elmish aka SAFE-Stack
Stars: ✭ 17 (-82.47%)
Mutual labels:  fable
json-as-xlsx
Create excel from json npm package
Stars: ✭ 103 (+6.19%)
Mutual labels:  full-stack
V2releases
A friendly ARM assembler and simulator for educational use
Stars: ✭ 46 (-52.58%)
Mutual labels:  fable

Simplified SAFE Stack

A lightweight alternative template to the full-fledged official SAFE Template. Lowers the entry barrier by choosing the simplest possible opinionated defaults:

  • Nuget for package management
  • FAKE build script as a console project (see ./build)
  • Saturn as server web framework
  • Fable.Remoting for client-server communications
  • Feliz as the React DSL on the front-end
  • Expecto for server unit-tests project
  • Fable.Mocha for client unit-tests project (runs in Node.js when on CI servers or live during development)
  • Serilog for logging server-side stuff
  • Scalable architecture by modelling logical server-side components following Fable.Remoting protocols
  • F# Analyzers support
  • Simple application variable configuration (see below sections)

Getting Started

To start using this template, simply clone this repository or use it as template via Github UI and you are good to go.

You need to have installed:

You can use the editor of your choice to work with the repository. VS Code is recommended with the Ionide extension for F# development but the template will also work just fine with Visual Studio, Rider or Visual Studio for Mac if you prefer to work with any of those.

Running The Application

To work with and develop the application, you need to both the server and the client project running at the same time. The server application is in the server directory and the client is in client directory. To run them both, simply open two shell tabs, each for either applications then:

  Shell tab c:\project\simplified-safe   Shell tab c:\project\simplified-safe
 -------------------------------------- --------------------------------------
  > cd server                            > cd client
  > dotnet restore                       > npm install
  > dotnet run                           > npm start

As shown here below

img

The server web application starts listening for requests at http://localhost:5000 where as the client application will be hosted at http://localhost:8080 during developments. All web requests made from the front-end are automatically proxied to the backend at http://localhost:5000. In production, there will no proxy because the front-end application will be served from the backend itself.

That is unless you are hosting the backend serverless and would like to host the front-end project separately.

Available Build Targets

You can easily run the build targets as follows:

  • ./build.sh {Target} on Linux, Mac or simulated bash on Windows
  • build {Target} on Windows
  • Hitting F5 where Build.fsproj is the startup project in Visual Studio or Rider

There are a bunch of built-in targets that you can run:

  • Server builds the server in Release mode
  • Client builds the client in production mode
  • Clean cleans up cached assets from all the projects
  • ServerTests runs the server unit-tests project
  • ClientTests runs the client unit-tests project by compiling the project first and running via Mocha in node.js
  • LiveClientTests runs a standalone web application at http://localhost:8085 that shows test results from the unit tests and recompiles whenever the tests change.
  • HeadlessBrowserTests builds the test project as web application and spins up a headless browser to run the tests and report results
  • Pack builds and packs both server and client into the {solutionRoot}/dist directory after running unit tests of both projects. You can run the result application using dotnet Server.dll in the dist directory.
  • PackNoTests builds and packs both server and client projects into {solutionRoot}/dist without running tests.
  • InstallAnalyzers installs F# code analyzers. You can configure which analyzers to install from the build target itself.

Configuring application variables: Server

The server web application picks up the environment variables by default from the host machine and makes them available from an injected IConfiguration interface. However, it adds a nice feature on top which allows to add more application-specific local variables by adding a JSON file called config.json inside your server directory:

{
  "DATABASE_CONNECTIONSTRING": "ConnectionString",
  "APP_NAME": "SimplifiedSafe",
  "VERSION": "0.1.0-alpha"
}

Just including the file will allow the variables to be picked up automatically and will also be made available through the IConfiguration interface.

Configuring application variables: Client

Even the client can use build variables. Using the Config.variable : string -> string function, you can have access to the environment variables that were used when the application was compiled. Webpack will pick them up automatically by default. To use local variables other than the environment variables, you add a file called .env into the client directory. This file is a dotenv variables file and has the following format:

KEY1=VALUE1
KEY2=VALUE2
WELCOME_MESSAGE=Welcome to full-stack F#

Then from your Fable application, you can use the variables like this:

Config.variable "WELCOME_MESSAGE" // returns "Welcome to full-stack F#"

Since this file can contain variables that might contain sensitive data. It is git-ignored by default.

Injecting ASP.NET Core Services

Since we are using Fable.Remoting in the template, make sure to check out the Functional Dependency Injection article from the documentation of Fable.Remoting that goes through the required steps of injecting services into the functions of Fable.Remoting APIs

F# Analyzers support

When developing the application using Ionide and VS Code, you can make use of F# analyzers that are built to detect certain types of specific pieces of code. By default the template doesn't include any analyzers but it is easy to add and install them using the InstallAnalyzers build target defined in build/Program.fs as follows:

Target.create "InstallAnalyzers" <| fun _ ->
    let analyzersPath = path [ solutionRoot; "analyzers" ]
    Analyzers.install analyzersPath [
        // Add analyzer entries to download
        // example { Name = "NpgsqlFSharpAnalyzer"; Version = "3.2.0" }
    ]

To install for example the NpgsqlFSharpAnalyzer package, simply uncomment the entry to make the code look like this:

Target.create "InstallAnalyzers" <| fun _ ->
    let analyzersPath = path [ solutionRoot; "analyzers" ]
    Analyzers.install analyzersPath [
        // Add analyzer entries to download
        { Name = "NpgsqlFSharpAnalyzer"; Version = "3.2.0" }
    ]

Then run the build target InstallAnalyzers again where it will delete the contents of analyzers directory and re-install all configured analyzers from scratch. Restart VS Code to allow Ionide to reload the installed analyzers. If you already have analyzers installed and adding new ones, you might need to do that from the terminal outside of VS Code because Ionide will lock the files in the analyzers path preventing the target from deleting the old analyzers.

IIS Support

The bundled application you get by running the Pack build target can be used directly as an application inside of IIS. Publishing on IIS requires that you make a separate Application Pool per .NET Core application with selected .NET CLR Version = No Managed Code. Then creating a new IIS Application which into the newly created Application Pool and setting the Physical Path of that Application to be the dist directory.

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].