Security News
Node.js EOL Versions CVE Dubbed the "Worst CVE of the Year" by Security Experts
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
@festicket/backline
Advanced tools
[![Build Status](https://semaphoreci.com/api/v1/projects/ed4738ad-82c8-4c98-9548-9ee54469ff71/1744679/shields_badge.svg)](https://semaphoreci.com/festicketci/backline) [![semantic-release](https://img.shields.io/badge/%20%20%F0%9F%93%A6%F0%9F%9A%80-semant
backline
is a collection of reusable components that are not specific to any particular Festicket UI.
See the master
branch Storybook Demo on Netlify. (This is automatically deployed with a GitHub webhook).
If you are creating a component that would be of no use to any website other than Festicket, it probably belongs in /app/components instead.
To reduce bundle size in consuming projects, import components via their full path in the dist
folder.
For example:
import PrimaryButton from '@festicket/backline/dist/components/buttons/PrimaryButton';
Don't import components the following way as this will increase bundle size since this type of import causes all of backline
to be imported at this point.
import { PrimaryButton } from '@festicket/backline'; // Don't do this
React SVG Components can be found in dist/components/svgs/generated/
.
In order to achieve a consistent style, only use these SVG components with the options provided. Never apply custom styling to them. The possible options for each SVG component can be seen in the Storybook for this project.
We use Husky and lint-staged to run precommit checks on files staged for commit. This includes es-lint validation.
Commit messages are generated using Commitizen and then verified using Commitlint.
It is important that all commits have the same format because these commits are then read by semantic-release and are used to decide the version number and release notes of any new release.
The format that we use is a customized version of (Conventional Commits)[https://www.conventionalcommits.org/] and uses the following format:
<type>: <description>
where type can be any of the following:
Type | Description |
---|---|
feat | A new feature |
fix | A bug fix |
docs | Documentation only changes |
refactor | Changes that neither fix a bug nor add a feature |
perf | Changes that improve performance |
test | Adding missing tests |
chore | Changes to the build process or auxiliary tools |
revert | Revert to a commit |
WIP | Work in progress |
When running git commit
commitizen will be run in place of your default text editor and will ask you a number of questions in order to generate a valid commit message.
NOTE: you can run git commit --no-edit
instead to skip the final step where the commit message you have created in commitizen is opened in your text editor.
The most important types are feat and fix, they are the only ones that will trigger a release and they are used to decide a version number and generate release notes. You will also have the opportunity with feat or fix commits to say whether your commit is a breaking change or not. A breaking change is any change that can cause dependent packages to break if they upgrade.
The basic format of a (semantic version)[https://semver.org/] number is MAJOR.MINOR.PATCH. When a release is done, the commit with the highest importance takes precedence when deciding the version number. So if a release solely consists of fixes, only the patch version will be bumped. If a feature is included then the minor version is bumped instead, and if any of the feat or fix commits include a breaking change then the major is bumped.
Each pull request on GitHub has its Storybook build deployed to a Deploy Preview url on Netlify. This will get automatically linked to in the GitHub pull request, and on the Jira ticket.
We use Semantic Release to automate releases of this project. Semantic Release will trigger new releases based on commit message formats that it recognises.
A new release will happen when a branch is merged into master
, provided at least one of the following conditions is met:
fix
will trigger a patch release (1.0.0 -> 1.0.1).
fix: stop component breaking
feat
will trigger a feature release (1.0.0 -> 1.1.0).
feat: add Header component
BREAKING CHANGE
in the message body will trigger a breaking release (1.0.0 -> 2.0.0).
docs: this part is irrelevant for triggering a breaking release
The import part is having BREAKING CHANGE in the body.
A new release will NOT happen if only commits of type refactor
are included in the pull request.
If a branch contains commit messages that would trigger multiple release types, the most 'breaking' release type will be applied.
After a branch is merged into master
, master
will be rebuilt on Semaphore.
If the build of master
is successful on Semaphore and contains a release commit, a server deploy will take place on Semaphore that will publish the latest version to NPM with the correct version.
SVG Components are dynamically generated in the repo. Please read all the following information before attempting to add a new SVG to the project.
Important
CSS attributes
and NOT CSS element
. There is a bug with svgr
/svgo
that means some colours in the SVG may get lost when the converted SVG uses a CSS element
.height
and width
attribute on the SVG element in the source code. You will need to manually add this to the source SVG if it doesn't have them. If they don't have this, they will end up with width: 100%
in IE11. // http://nicolasgallagher.com/canvas-fix-svg-scaling-in-internet-explorer/New SVGs are added by placing an SVG source file inside a folder in /svgs/
. Each type of folder generates SVGs with different variation - based on the template that is configured for that folder in scripts/svgr.sh
Running yarn svgr
will take all the SVGs from the source svg folders in /svgs
and use svgr
to generate React components from them. These will be placed in src/components/svgs/generated/
.
If you make changes to an existing SVG, you must make the changes to the source SVG, as any changes to the files in src/components/svgs/generated/
will be overwritten the next time yarn svgr
is run.
We use framer-motion
(docs) for animations in ui-components. Have a good look around the docs before you read any more.
Where possible, trust the library's in-built timings. They are tried and tested and allow for lightning-quick setup of animations. If design decide that we really do need something custom, take a look at the transitions docs.
FAQs
[![Build Status](https://semaphoreci.com/api/v1/projects/ed4738ad-82c8-4c98-9548-9ee54469ff71/1744679/shields_badge.svg)](https://semaphoreci.com/festicketci/backline) [![semantic-release](https://img.shields.io/badge/%20%20%F0%9F%93%A6%F0%9F%9A%80-semant
The npm package @festicket/backline receives a total of 158 weekly downloads. As such, @festicket/backline popularity was classified as not popular.
We found that @festicket/backline demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 8 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.