Trending Projects is available as a weekly newsletter please sign up at www.iainfreestone.com to ensure you never miss an issue.
1. Sweet Alert
A beautiful replacement for JavaScript's "alert"
t4t5 / sweetalert
A beautiful replacement for JavaScript's "alert"
A beautiful replacement for JavaScript's "alert"
Installation
$ npm install --save sweetalert
Usage
import swal from 'sweetalert';
swal("Hello world!");
Upgrading from 1.X
Many improvements and breaking changes have been introduced in the 2.0 release. Make sure you read the upgrade guide to avoid nasty suprises!
Guides
Documentation
Examples
An error message:
swal("Oops!", "Something went wrong!", "error");
A warning message, with a function attached to the confirm message:
- Using promises:
swal({
title: "Are you sure?",
text: "Are you sure that you want to leave this page?",
icon: "warning",
dangerMode: true,
})
.then(willDelete => {
if (willDelete) {
swal("Deleted!", "Your imaginary file has been deleted!", "success")
ā¦2. Anime.js
Anime.js is a lightweight JavaScript animation library with a simple, yet powerful API. It works with CSS properties, SVG, DOM attributes and JavaScript Objects.
juliangarnier / anime
JavaScript animation engine
anime.js
JavaScript animation engine | animejs.com
Anime.js (/ĖƦn.É.meÉŖ/
) is a lightweight JavaScript animation library with a simple, yet powerful API.
It works with CSS properties, SVG, DOM attributes and JavaScript Objects
Getting startedĀ |Ā DocumentationĀ |Ā Demos and examplesĀ |Ā Browser support
Getting started
Download
Via npm
$ npm install animejs --save
or manual download.
Usage
ES6 modules
import anime from 'animejs/lib/anime.es.js';
CommonJS
const anime = require('animejs');
File include
Link anime.min.js
in your HTML :
<script src="anime.min.js"></script>
Hello world
anime({
targets: 'div',
translateX: 250,
rotate: '1turn',
backgroundColor: '#FFF',
duration: 800
});
Documentation
- Targets
- Properties
- Property parameters
- Animation parameters
- Values
- Keyframes
- Staggering
- Timeline
- Controls
- Callbacks and promises
- SVG Animations
- Easing functions
- Helpers
Demos and examples
3. cote
A Node.js library for building zero-configuration microservices. cote lets you write zero-configuration microservices in Node.js without nginx, haproxy, redis, rabbitmq or anything else. It is batteries ā and chargers! ā included.
cote ā A Node.js library for building zero-configuration microservices
cote lets you write zero-configuration microservices in Node.js without nginx haproxy, redis, rabbitmq or anything else. It is batteries ā and chargers! ā included.
Join us on for anything related to cote.
Features
- Zero dependency: Microservices with only JavaScript and Node.js
- Zero-configuration: no IP addresses, no ports, no routing to configure
- Decentralized: No fixed parts, no "manager" nodes, no single point of failure
- Auto-discovery: Services discover each other without a central bookkeeper
- Fault-tolerant: Don't lose any requests when a service is down
- Scalable: Horizontally scale to any number of machines
- Performant: Process thousands of messages per second
- Humanized API: Extremely simple to get started with a reasonable API!
Develop your first microservices in under two minutes:
in time-service.js
...
const cote = require('cote');
const timeService = new cote.Responder({ name: 'Time Service'
ā¦4. Chroma.js
Chroma.js is a small-ish zero-dependency JavaScript library (13.5kB) for all kinds of color conversions and color scales.
Chroma.js
Chroma.js is a tiny small-ish zero-dependency JavaScript library (13.5kB) for all kinds of color conversions and color scales.
Usage
Install from npm
npm install chroma-js
Import package into project
import chroma from "chroma-js";
Initiate and manipulate colors:
chroma('#D4F880').darken().hex(); // #9BC04B
Working with color scales is easy, too:
scale = chroma.scale(['white', 'red']);
scale(0.5).hex(); // #FF7F7F
Lab/Lch interpolation looks better than RGB
chroma.scale(['white', 'red']).mode('lab');
Custom domains! Quantiles! Color Brewer!!
chroma.scale('RdYlBu').domain(myValues, 7, 'quantiles');
And why not use logarithmic color scales once in your life?
chroma.scale(['lightyellow', 'navy']
ā¦5. Plotly.js
Plotly.js is a standalone Javascript data visualization library. Can be used to produce dozens of chart types and visualizations, including statistical charts, 3D graphs, scientific charts, SVG and tile maps, financial charts and more.
Plotly.js is a standalone Javascript data visualization library, and it also powers the Python and R modules named plotly
in those respective ecosystems (referred to as Plotly.py and Plotly.R).
Plotly.js can be used to produce dozens of chart types and visualizations, including statistical charts, 3D graphs, scientific charts, SVG and tile maps, financial charts and more.
Contact us for Plotly.js consulting, dashboard development, application integration, and feature additions.
Table of contents
- Load as a node module
- Load via script tag
- Bundles
- Alternative ways to load and build plotly.js
- Documentation
- Bugs and feature requests
- Contributing
- Notable contributors
- Copyright and license
- Community
Load as a node module
Install a ready-to-use distributed bundle
npm i --save plotly.js-dist-min
and use import or require in node.js
// ES6 module
import Plotly from 'plotly.js-dist-min'
// CommonJS
var Plotly = require('plotly.js-dist-min')
You may also consider using plotly.js-dist
if you prefer using an unminifiedā¦
6. Complete Intro to React
The Complete Intro to React, the fifth version
btholt / complete-intro-to-react-v5
The Complete Intro to React, the fifth version
All PRs and issues for the course code and website have been resolved as of November 29th, 2019. The code for each commit and branch has also been tested!
Welcome to the Complete Intro to React v5 and Intermediate React v2!
Before starting the course, please have VSCode or another code editor installed.
The master branch and commits within are all covered in Introduction to React v5. The other branches, excluding the gh-pages-src and gh-pages branches (these create the course website), are all covered in Intermediate React as modular segments that can be taken individually, or out of order.
Brian is using a font called Dankmono (not necessary to install -- just for those curious), but FiraCode is another great option. This course was written for and recorded by Frontend Masters. The code here is licensed under the Apache 2.0ā¦
7. ReactContentLoader
SVG-Powered component to easily create placeholder loadings (like Facebook's cards loading).
danilowoz / react-content-loader
āŖ SVG-Powered component to easily create skeleton loadings.
SVG-PoweredĀ componentĀ toĀ easilyĀ createĀ placeholderĀ loadingsĀ (likeĀ Facebook'sĀ cardsĀ loading).
Features
-
āļø Ā Customizable:Ā FeelĀ freeĀ toĀ changeĀ theĀ colors,Ā speed,Ā sizes,Ā andĀ evenĀ RTL; -
š Ā PlugĀ andĀ play:Ā withĀ manyĀ presetsĀ toĀ use,Ā seeĀ theĀ examples; -
āļø Ā DIY:Ā useĀ theĀ create-content-loaderĀ toĀ createĀ yourĀ ownĀ customĀ loadersĀ easily; -
š± React Native support: same API, as same powerful features; -
āļø Really lightweight: less than 2kB and 0 dependencies for web version;
Index
GettingĀ Started
npm i react-content-loader --save
yarn add react-content-loader
For React Native
npm i react-content-loader react-native-svg --save
yarn add react-content-loader react-native-svg
CDNĀ fromĀ JSDELIVR
Usage
ThereĀ areĀ twoĀ waysĀ toĀ useĀ it:
1.Ā Presets,Ā seeĀ theĀ examples:
import ContentLoader, { Facebook } from 'react-content-loader'
const MyLoader = () => <ContentLoader />
const MyFacebookLoader = () => <Facebook /
ā¦8. goober
goober, a less than 1KB css-in-js alternative with a familiar API
cristianbote / goober
š„ goober, a less than 1KB š css-in-js alternative with a familiar API
šŖ The Great Shave Off Challenge
Can you shave off bytes from goober? Do it and you're gonna get paid! More info here
Motivation
I've always wondered if you could get a working solution for css-in-js with a smaller footprint. While I was working on a side project I wanted to use styled-components, or more accurately the styled
pattern. Looking at the JavaScript bundle sizes, I quickly realized that I would have to include ~12kB(styled-components) or ~11kB(emotion) just so I can use the styled
paradigm. So, I embarked on a mission to create a smaller alternative for these well established APIs.
Why the peanuts emoji?
It's a pun on the tagline.
css-in-js at the cost of peanuts
š„ goober
Table of contents
9. Tagify
Transforms an input field or a textarea into a Tags component, in an easy, customizable way, with great performance and small code footprint, exploded with features.
yairEO / tagify
š lightweight, efficient Tags input component in Vanilla JS / React / Angular / Vue
Tagify - tags input component
Transforms an input field or a textarea into a Tags component, in an easy, customizable way
with great performance and small code footprint, exploded with features
Vanilla
š See Demos š
Table of Contents
- Table of Contents
- Installation
- Features
- Building the project
- Adding tags dynamically
- Output value
- Ajax whitelist
- Edit tags
- Validations
- Drag & Sort
- DOM Templates
- Suggestions list
- Mixed-Content
- Single-Value
- React
- jQuery version
- CSS Variables
- Methods
- Events
- Hooks
- Settings
Installation
Option 1 - import from CDN:
Place these lines before any other codeā¦
10. Polacode
Polaroid for your code
Polacode ā Polaroid for your code šø
Why?
You have spent countless hours finding the perfect JavaScript grammar, matching it with a sleek-looking VS Code theme, trying out all the best programming fonts.
You take three days porting over your theme before starting to use VS Code.
You shell out $200 for italic cursive html attributes.
The code has to look right.
Tips
- Resize the snippet / container by dragging the lowerright corner
- Use
polacode.target
,polacode.shadow
,polacode.transparentBackground
andpolacode.backgroundColor
to control image appearance
Demo
Material Theme Palenight + Fira Code
Credit
Thanks to @tsayen for making dom-to-image, which Polacode is using for generating the images.
Thanks to Dawn Labs for making Carbon that inspired Polacode.
Many color are taken from the elegant Nord theme by @arcticicestudio.
Download button animation is made with Vivusā¦
Trending Projects is available as a weekly newsletter please sign up at www.iainfreestone.com to ensure you never miss an issue.
If you enjoyed this article you can follow me on Twitter where I regularly post bite size tips relating to HTML, CSS and JavaScript.
Top comments (12)
Hi
You can add my open-source tool to the list.
Databunker is a Swiss army knife tool for storing personal records or PII:
databunker.org/
Node.js example:
github.com/securitybunker/databunk...
Thanks. Awesome post ;)
So useful, thanks
everything is about JS and i'm not even surprised anymore :)
awesome post!
Anime.js š Yes I am an Anime geek š
Thank you, Very useful
Sweetalert I'm using from years now,
But why it's trending ? any new update ?
github.com/sweetalert2/sweetalert2
Thanks so much. useful content. Bookmarked.
Thanks. I always bookmark your content š.
Thank you, I enjoy compiling it each week. So many great resources out there
Thxxx