0.3.46 • Published 4 years ago

highmark v0.3.46

Weekly downloads
13
License
MIT
Repository
-
Last release
4 years ago

Highmark.js

Please note that Highmark.js is in ongoing initial development and exists as an npm package to test production builds and distribution only.

To start up a development server

yarn run server:dev - Builds the files in watch mode and runs server

Setup

  • Install node packages
  • Setup express server
  • Create seperate client and server react entrypoints

    • Client entry rendered with BrowerRouter
    • Server entry rendered with StaticRouter
  • Server Side Rendering

    • Create a server version of webpack bundle
    • Reduce server bundle size by forcing external packages to not be bundled (not sure if this will still work in Ruby environment, was built for node)
    • Use isomorphic-style-loader to avoid CSS trying to add to DOM on server
    • Use react-universal to do lazy loading client-side and instant loading server-side
    • Add babel-plugin-universal-import so babel picks up react-universal properly
    • Limit server-side chunks to 1 to avoid async loading files
    • Add extract-css-chunks-webpack-plugin to get css chunks in webpack stats output (of the client bundle, server bundle is now only one file)
    • Enable webpack stats output (so server knows what script and link tags to send on a page)
    • Add method to push data back to head of page (PushDataTag)
  • Add webpack-flush-chunks and patch it into react-universal

  • Import stats file and plugin to webpack-flush-chunks

  • Load initial data server-side and prefill page (React.Suspense required)

    • It could be possible to do initial render pass, collect all the promises and then resolve them manually into page headers
  • Avoid loading data if page is pre-filled
    • Data is cached based on resolver and serialized arguments
    • Redux does something VERY similar to prefill the client store
  • Support handling oEmbed version of page based on react-router
    • Extend the push data handler to accept oEmbed tags? Then just send that result instead of page render
  • Move more packages into peerDependancy

Server

  • Directory based page routing
    • Add directory specific configuration files
    • Remove react-router and replace with a smaller custom library? (possibly offer as a config option)
  • Serve public files
  • Redis integration for publicly build pages (by specifying redis configuration in highmark.config)
  • Add a path for API calls (server-bundle only, does not use the React-router pathing)
  • Add support for changing the HTML lang attribute

Extra server things

  • Handle redirects and error codes generated by bundle
  • Send CSS/JS assets as Link prefetch headers
  • Send initial CSS as inline stylesheet
  • Send Image assets as HTTP Push headers (though not possible with )

Images

  • Resize, convert, and minify all images automatically
    • Additionally create a "sample" data url to blend the image in
    • Highly extensible per-image config files
  • Image Component
    • Finds all versions of image and creates a picture source set
    • Creates temporary "blur" render while image is loading
  • CSS loader that fills in url() rules with appropriate image-set()
  • Scoping / Chunking assets manifest to js bundle that uses them.

Build Step

  • Single command development server setup
  • Single command production build client/server
  • Directory copy Highmark instead of indivdual files
0.3.31

5 years ago

0.3.30

5 years ago

0.3.39

4 years ago

0.3.38

4 years ago

0.3.37

4 years ago

0.3.36

4 years ago

0.3.35

4 years ago

0.3.34

4 years ago

0.3.33

5 years ago

0.3.32

5 years ago

0.3.29

5 years ago

0.3.28

5 years ago

0.3.42

4 years ago

0.3.41

4 years ago

0.3.40

4 years ago

0.3.46

4 years ago

0.3.45

4 years ago

0.3.44

4 years ago

0.3.43

4 years ago

0.3.9

5 years ago

0.3.17

5 years ago

0.3.16

5 years ago

0.3.15

5 years ago

0.3.14

5 years ago

0.3.13

5 years ago

0.3.12

5 years ago

0.3.11

5 years ago

0.3.10

5 years ago

0.3.20

5 years ago

0.3.27

5 years ago

0.3.26

5 years ago

0.3.24

5 years ago

0.3.23

5 years ago

0.3.22

5 years ago

0.3.21

5 years ago

0.3.19

5 years ago

0.3.18

5 years ago

0.3.8

5 years ago

0.3.7

5 years ago

0.3.6

5 years ago

0.3.5

5 years ago

0.3.4

5 years ago

0.3.2

5 years ago

0.3.3

5 years ago

0.3.1

5 years ago

0.3.0

5 years ago

0.2.3

5 years ago

0.2.2

5 years ago

0.2.1

5 years ago

0.2.0

5 years ago

0.1.9

5 years ago