Coder Social home page Coder Social logo

races-test's Introduction

I used the Polymer starter kit to start the project off.

These are the files I worked on:

  • backend/generate-data,js - a nodejs back end that generates a bunch of races with random names, start times etc
  • my-app.html - The 'page' component. This component create three different race lists (Horses, Harnesses and Greyhounds) and feeds each a filtered array. Each array is based on the data returned from the back end
  • race-list-data.html - Encapulates the ajax call. When loaded the component will fire off an ajax call straight away. Whenever an ajax call completes the component creates a two minute delay before reloading the list. The my-app component binds to race-list-data's data property to whenever that property is updated with new data from the server, my-app automatically filters the data into groups.
  • race-list.html - Component that further filters the race list to remove any races that have already started/closed. Every second race-list will update the 'currentDate' properties which in turn updates the filtered list, which in turn removes any race that has already closed.
  • race-card.html - Displays the race information along with the count down timer. The timer updates whenever 'currentDate' is updated by race-list.

The whole idea is to use data binding so that when data is updated, the UI takes action and changes itself to match the new data.

I've left some of the original readme file below in case you don't have the Polymer CLI installed. If you already have the Polymer CLI installed then the these are the steps to launch the application locally:

To start the random race generator backend:

node backend/generate-data.js

To download the Polymer application's dependencies:

bower install

To start the Polymer application:

polymer serve --open

Setup

Prerequisites

First, install Polymer CLI using npm (we assume you have pre-installed node.js).

npm install -g polymer-cli
Initialize project from template
mkdir my-app
cd my-app
polymer init starter-kit

Start the development server

This command serves the app at http://localhost:8080 and provides basic URL routing for the app:

polymer serve --open

Build

This command performs HTML, CSS, and JS minification on the application dependencies, and generates a service-worker.js file with code to pre-cache the dependencies based on the entrypoint and fragments specified in polymer.json. The minified files are output to the build/unbundled folder, and are suitable for serving from a HTTP/2+Push compatible server.

In addition the command also creates a fallback build/bundled folder, generated using fragment bundling, suitable for serving from non H2/push-compatible servers or to clients that do not support H2/Push.

polymer build

Preview the build

This command serves the minified version of the app at http://localhost:8080 in an unbundled state, as it would be served by a push-compatible server:

polymer serve build/unbundled

This command serves the minified version of the app at http://localhost:8080 generated using fragment bundling:

polymer serve build/bundled

Run tests

This command will run Web Component Tester against the browsers currently installed on your machine:

polymer test

Adding a new view

You can extend the app by adding more views that will be demand-loaded e.g. based on the route, or to progressively render non-critical sections of the application. Each new demand-loaded fragment should be added to the list of fragments in the included polymer.json file. This will ensure those components and their dependencies are added to the list of pre-cached components and will be included in the bundled build.

races-test's People

Watchers

Eric Murano avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.