Issue #415 (Transforms, JS Libs, JSON/DB, React)
When you write CSS transforms, no doubt you use the transform property along with one of the transform functions including rotate(), scale(), translate(), skew(), along with a slew of others.
In case you missed it, however, the W3C's CSS Transforms Module Level 2 has added three individual transform properties:
These are intended to replace three of the function values, simplifying the use of transforms. Previously when declaring multiple transforms on a single element, it was a pain to do an override. For example:
transform: scale(.8) translate(10px, 30px) rotate(45deg);
In the code above, my intention is to only override the scale() setting in the second declaration block, but because I've omitted the translate() and rotate() values, those get reset as if they weren't originally applied. Not ideal and usually not what you want.
Using individual properties for these transforms makes this much easier to deal with. So far there are three of such properties and I don't know if more will be added (for example, there's none for skew or for the axis-based functions like rotateX or translateY).
The only major problem with these three new properties right now is the fact that Firefox and Safari are the only browsers that support them. So they're clearly not ready for production yet. Nonetheless, these are good to keep in mind since they will greatly simplify the process of transform overrides (at least for the three that are supported).
Now on to this week's tools!
TLDR Newsletter - Byte Sized News for Busy Techies
TLDR is a free daily newsletter with links and TLDRs of the most interesting stories in tech 📱, science 🚀, and coding 💻! sponsored
A simple web games library that includes a game loop, input, sounds, music, and tile sets.
A community-governed collection of open source mapping libraries for web and mobile applications (iOS/Android).
An open-source low-code framework to build web apps, admin panels, business intelligence dashboards, workflows, and CRUD apps with ease.
A ~1kb virtual DOM alternative that aims to fix many of the problems inherent in other similar solutions.
Fast and low overhead web framework for Node.js with a powerful plugin architecture, inspired by hapi and Express.
A type-friendly web framework for Node.js apps, written in TypeScript.
A data-binding function for the DOM (an older project).
JSON Tools, Databases, etc.
Master Gatsby: Learn Gatsby, React & Friends
A search engine for datasets. Using a simple keyword search, discover datasets hosted in thousands of repositories across the web.
A universal CLI written in Go, for PostgreSQL, MySQL, Oracle, SQLite3, Microsoft SQL Server, as well as NoSQL and non-relational databases.
A collection of color palettes in JSON format, taken from a popular website that lets you browse, create, and share color palettes.
A CDN for GraphQL APIs (not free) that allows you to reduce your origin traffic by up to 95%.
An easy to use JSON database written with ease of setup and effective memory management.
Converts CSV to JSON or vice-versa. Just upload a CSV file or input some JSON, then copy or download the resulting JSON or CSV file.
A GraphQL client built for rapid iteration that makes using your API enjoyable by generating queries at runtime based on the data your app consumes.
A set of libraries for building complex rules, serializing them as JSON, then sharing them between front-end and back-end.
A high-performance, open-source SQL database for applications in financial services, IoT, machine learning, DevOps, and observability.
A lightweight Linked Data format that provides a way to help JSON data interoperate at web-scale, ideal for REST Web services, and unstructured databases such as Apache CouchDB and MongoDB.
A fast, open-source Online analytical processing (OLAP) database management system that allows you to generate analytical reports using SQL queries in real-time.
Master Gatsby: Learn Gatsby, React & Friends
A simple tagging component, inspired by Gmail's "To" field in the compose window.
A user-friendly React component to build queries, inspired by jQuery QueryBuilder.
React Multiselect Dropdown
React component that provides multi-select functionality with various features like selection limit, CSS customization, checkbox, disable preselected values, flat array, keyboard navigation, and grouping features.
React Cool Virtual
A tiny React hook for easily rendering large datasets, overcoming some of the problems common in other solutions.
A Storybook alternative that builds 20x faster and helps you develop React UI components in isolation while staying organized and productive.
A configurable embeddable rich text editor built with Draft.js that aims for a mouse-free experience during editing.
Super fast and lightweight React package that easily implements zooming, panning, and pinching for HTML elements.
A flexible image gallery lightbox with native-feeling touch gestures and smooth animations.
React Easy Emoji
A super minimal emoji rendering utility for React.
A React library that displays a component for generating a customized avatar.
React Grid System
A powerful Bootstrap-like responsive grid system for React.
An accessible, CSS-agnostic range slider component for React.
React Time Ago
International relative time formatting for React.
Want the latest in productivity tools and articles? Try my other newsletter, Tech Productivity. Includes tools, articles, and tips on productivity and remote work.
A Tweet for Thought
Here's one comic artist's explanation on how to write ALT text for comic book panels.
Send Me Your Tools!
Made something? Send links via Direct Message on Twitter @WebToolsWeekly (details here). No tutorials or articles, please. If you have any suggestions for improvement or corrections, feel free to reply to this email.
Before I Go...
If you're a designer and a Trekkie, you'll love Star Trek + Design, a showcase of the aesthetics and set designs from Star Trek episodes, which you can view by categories (e.g. Glassware, Tableware, Lighting, etc).
Thanks to all for subscribing and reading!