Skip to content

Commit

Permalink
Release 1.1.0 (#3)
Browse files Browse the repository at this point in the history
* Bump version to 1.0.1

* Minify CSS and JS in production (#4)

* Add CSS minification step to production build.

* Add terser and JS compression script using foreach-cli

* Update CHANGELOG.

* * Add CSS minification step to production build. (#6)

* Add terser and JS compression script using foreach-cli

* Update CHANGELOG.

Co-authored-by: Elise Hein <elisehein@gmail.com>

* GH Actions workflow for linting and testing (#7)

* Add lint and test GH workflow.

* Add .eslintignore to ignore test files.

* Fix some eslint errors.

* Fix some stylelint issues.

* Duration helper class (#8)

* Add a Duration helper object and make a start with conversions.

* Add shortcut properties for 1, 2, 3 second durations.

* Update CHANGELOG.

* Fix date in CHANGELOG.

* Fix links in CHANGELOG.

* A11y updates (#9)

* Adjust outline offsets.

* Use a different ARIA label for thumbnail diagram SVGs.

* Make pendulum arm keyboard focusable and clickable.

* Improve keyboard focusability by preventing outline on click, and make fig. 18 options keyboard focusable.

* Add fill animation to pendulum click overlay to better indicate clickability.

* Add aria-live, aria-selected and aria-current to the semantics between the toolbar and the figure.

* Hide the animated caption from screen readers and add an accessible, visually hidden caption.

The animated caption, even with role="text", was being read out letter
by letter.

Resources for the current approach:

- https://css-irl.info/how-to-accessibly-split-text/
- https://kittygiraudel.com/2021/02/17/hiding-content-responsibly/?ref=uxcollective

* Bump up max diagram size.

Fig. 18 was quite hard to read on a large desktop screen.

* Use aria-current instead of aria-selected for figure toolbar.

aria-selected implies role=tab and role=tablist, which, in turn,
required each tab item to aria-control a specific tab. We don't render
each figure immediately and switch visibility via tabbing, so it's not
possible to add the correct aria roles. In any case, since these are
anchor tags that change the URL, aria-selected may be more appropriate
anyway.

* Try out native scrollIntoView for fig. 18 boxes.

Reasons not to go with this:
- Smooth option not supported on Safari
- Not in sync with the arrow drawing, so does it actually help?
- Interferes with manual scrolling?

* Revert "Try out native scrollIntoView for fig. 18 boxes."

This reverts commit e1a9c93.

Too much effort to get to work nicely.

* Update CHANGELOG.

* Loop fig. 42 in reverse after caption appears. (#10)

* Loop fig. 42 in reverse infinitely.

* Reuse existing star animations instead of infinitely creating new ones. Fix beginAnimation() done handler not being cleaned up.

* Use passed in onLightUp instead of keeping a reference on this.

* Add jitter just before reverse animation in fig. 42.

* Reduce blur on fig. 42 thumbnail.

* Update CHANGELOG.

* Light up fig. 18 when new boxes are drawn. (#11)

* Light up fig. 18 when new boxes are drawn.

* Update CHANGELOG.

* An approach to fig. 18 where the caption also disappears during the reverse loop.

* Erratic rotation in fig. 43. Distinguish between SVG and HTML diagrams. (#12)

* Split Diagram into SVGDiagram and HTMLDiagram in prep for HTML+CSS version of fig. 43.

This also includes removing (buggy) attribute mirroring from Diagram, as
we don't use it.

* Replace SVG cube with rotating CSS keyframes cube.

* Different styling in fig. 43 for thumbnail diagram.

* Fix fig. 43 keyframes on Safari by explicitly defining rotation 0 > 90 > 180 > 270. Separate scale animation from rotation.

* Add random fuzziness to fig. 43.

* Move fuzziness handling to SchematicsFigure to include figcaption. Fine-tune fig. 43 animations.

* Add zero-case test to Duration.

* Clean up fuzzy and light up on figure change.

* Add svg and html variation classnames to diagram and use for positioning.

* Reduce repetition in positioning the diagram custom element and its children.

* Adjust fig. 43 timing.

* Attach figure behavior callbacks to diagram element after init instead of passing with draw functions.

* Implement DiagramFactory to take care of passing figureBehaviors on init.

* Update CHANGELOG.

* Add quick offset drop shadow to hiding duration and light up fig. 14 on start.

* Update CHANGELOG.

* Move some things out of main.css

* Small CSS tidy-ups.

* Fix figure toolbar breakpoints for showing active vs all links.

Also show all links on tablets if they fit.

* Disable transition and animation durations if @prefers-reduced-motion.

This doesn't include the actual figure SVG animations, only CSS.

* Revert "Disable transition and animation durations if @prefers-reduced-motion."

Will do it properly all in one go along with the figures themselves.
Also need to research acceptable levels of motion instead of disabling
everything.

This reverts commit 1066454.

* Update CHANGELOG and versions.

Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
  • Loading branch information
elisehein and dependabot[bot] authored Jun 18, 2021
1 parent eff383d commit 0653066
Show file tree
Hide file tree
Showing 45 changed files with 15,577 additions and 831 deletions.
1 change: 1 addition & 0 deletions .eslintignore
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
**/*.test.js
2 changes: 1 addition & 1 deletion .eslintrc.json
Original file line number Diff line number Diff line change
Expand Up @@ -106,7 +106,7 @@
],
"max-classes-per-file": [
"error",
2
3
],
"max-depth": "error",
"max-len": "off",
Expand Down
41 changes: 41 additions & 0 deletions .github/workflows/lint-and-test.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
name: Run linter and tests

on:
pull_request:

jobs:
test:

runs-on: ubuntu-latest

steps:

# Check out the repo
- uses: actions/checkout@v2

- name: Use Node.js 12.x
uses: actions/setup-node@v1
with:
node-version: 12.x

- name: Cache node modules
uses: actions/cache@v1
env:
cache-name: cache-node-modules
with:
path: node_modules
key: ${{ runner.os }}-build-${{ env.cache-name }}-${{ hashFiles('**/package-lock.json') }}

- name: Install dependencies
run: npm install;

- name: Lint JS files
run: npm run lint:js
continue-on-error: true

- name: Lint CSS files
run: npm run lint:css
continue-on-error: true

- name: Run tests
run: FORCE_COLOR=1 npm test
30 changes: 27 additions & 3 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,12 +5,36 @@ All notable changes to this project will be documented in this file.
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).

## [Unreleased]
## [1.1.0] – 2021-06-18

## [1.0.0] – 2019-02-25
### Added

* Compression scripts for CSS (using `cssnano`) and JS (using `terser` and `foreach-cli`) to run in production on Netlify ([#4](https://github.com/elisehein/schematics/pull/4)).
* Keyboard focusability for the SVG elements in figs. 18 and 36 ([#9](https://github.com/elisehein/schematics/pull/9)).
* ARIA roles and attributes to indicate the live figure region and toolbar controlling it ([#9](https://github.com/elisehein/schematics/pull/9)).
* A different a11y description for each figure depending on whether it's a thumbnail or not ([#9](https://github.com/elisehein/schematics/pull/9)).
* Reverse looping in fig. 42 after the caption has appeared ([#10](https://github.com/elisehein/schematics/pull/10)).
* Light up fig. 18 when new boxes are drawn ([#11](https://github.com/elisehein/schematics/pull/11)).

### Changed

* Replaced simplistic SVG cube animation with HTML + CSS 3D animation in fig. 43 ([#12](https://github.com/elisehein/schematics/pull/12)).
* Changed the figure hiding effect to include a quick subtle drop-shadow.

### Fixed

* Screen-reader friendly figure caption ([#9](https://github.com/elisehein/schematics/pull/9));

### Refactored

* Refactored how millisecond-second durations are handled ([#8](https://github.com/elisehein/schematics/pull/8)).
* Split `Diagram` into `SVG` and `HTML` subtypes ([#12](https://github.com/elisehein/schematics/pull/12)).

## [1.0.0] – 2021-06-12

The initial release of Schematics including the first five figures (figs 14, 18, 36, 42, 43).

[Unreleased]: https://github.com/elisehein/schematics/compare/1.0.0...staging
[Unreleased]: https://github.com/elisehein/schematics/compare/1.1.0...staging
[1.1.0]: https://github.com/elisehein/schematics/compare/1.0.0...1.1.0
[1.0.0]: https://github.com/elisehein/schematics/compare/c8aa7d3e4fe78a3df0a3add04f7ba1d121b7a38e...1.0.0

Loading

0 comments on commit 0653066

Please sign in to comment.