Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@gn-as/styles

Package Overview
Dependencies
Maintainers
2
Versions
16
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@gn-as/styles

General GN Advanced Science styles package

  • 2.0.0-alpha.1
  • alpha
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
205
increased by13.89%
Maintainers
2
Weekly downloads
 
Created
Source

GN Advanced Science Styles

The aim of this project is to enable the GN Advanced Science organization to have a single source of truth for GN Advanced Science-related 'styles'.

Specifically, those styles relating to websites and web applications.

Installation

The official release can be installed by executing:

npm install @gn-as/styles

To install the "cutting edge" release, execute:

npm install @gn-as/styles@next

Usage

Applications with asset bundlers (Vite, Grunt, etc)

More information on this coming soon. However, if you are using a modern application bundler like Vite, WebPack, or Grunt, you should be able to simply import the way you would CSS from any other NPM module that ships with CSS.

In the case of Vite (in a Svelte codebase), this amounts to:

<script>
  import '@gn-as/styles/color.css'
  ...
</script>

Static/Legacy web applications/sites

If you have the ability to leverage NodeJS modules, you can get the current version of the styes into your local codebase via:

npm install @gn-as/styles

If you don't have this option, you can download your preferred release from the releases page. Alternatively, you can use a hosted version from Unpkg if necessary (not suggested for production deployments).

After you have decided where you want to host the actual CSS files, using the library is just like using any other CSS file...just include a link tag as you normally would. For example:

<link rel="stylesheet" href="/styles/gn-as/styles/app.css" type="text/css" />

Note for legacy applications

You may want to integrate the @gn-as/styles library slowly to avoid a major rewrite of all your markup and CSS rules. To simplify this process and avoid rule/naming conflicts, we release a "scoped" version of all CSS files (other than the color variable definitions). The "scoped" rules are all nested under a class of owlie, allowing you to isolate the impact to specific elements or pages in your application. The directory structure and file names are identical with the exception that all "scoped" CSS files are located inside a "scoped" directory. Therefore, if you copied all the CSS files from package into a /styles/gn-as directory, you would reference the top-level app.css file like this:

<link rel="stylesheet" href="/styles/gn-as/app.css" type="text/css" />

...and the scoped version would be available like this:

<link rel="stylesheet" href="/styles/gn-as/scoped/app.css" type="text/css" />

Usage example:

<link rel="stylesheet" href="/styles/gn-as/styles/scoped/app.css" type="text/css" />

...
<main>
  <p>This element would retain your application's styling rules.</p>
</main>

<main class="owlie">
  <p>Only this element would inherit the "gn-as/styles" styling rules.</p>
</main>

Developer notes

Branches

We follow the typical "branch, develop, submit merge request" flow of development. Here is an overview of our branch names:

  • main: This is the default branch that you will see in the GitLab interface and what should be used when starting work on a new branch and what you should (typically) set as the "base" branch when creating a merge request. Your work must be integrated into this branch in order to be released.
  • next: This branch is merged into from main when we want to push a "regular" @next dist-tag release (more info). This would result in a package that you can install via npm install @gn-as/styles@next, but it would not install on the "typical" npm install @gn-as/styles command. When the @next release is ready for an "official" standard release, we would merge @next into the release branch.
    • Note that in the event that we didn't need to "hide" a release under the @next dist tag, you can just go directly from main into @release to get a standard (visible) release.
  • release: The main (or next) branch is merged into this branch when we are ready to cut a new release. Therefore, unless you are interested in generating a new release (from the main branch), this should not be set as the "destination" branch in a merge request and should be the parent of any branches you create. It should never be set as the "base" branch in a Merge Request either.
  • other branches: Create forks or branches as you like. If you don't "own" the branch, don't rebase it. If you are collaborating with people on a branch, be a good citizen (don't rebase unless you've confirmed with them, etc).

Tooling

Although the repository is comprised of CSS files, there are a few development tools installed to ensure we maintain a consistent codebase. You will want to install NPM dependencies:

npm install

Versioning

We follow the Semantic Versioning software versioning specification (see semver.org).

All releases are automatically generated and version numbering are based on commit messages (see below).

Commit message formatting

We follow the Conventional Commits specification on commit messages. The tooling installed (Husky, et al) will verify the format of your commit message, so if you are not familiar with Conventional Commits...there are guard rails to help you out.

CSS formatting

We have common configuration files in place that most editors should automatically both recognize and honor (.prettierrc, etc) as you are editing. There is also a commit hook that will fix/lint all files being committed so again, there are guard rails.

If you'd like to run a format-check across all CSS files, you can run:

npm run check-css

If you'd like to both check and write the fixes across all CSS files, you can issue:

npm run format-css

FAQs

Package last updated on 07 Aug 2024

Did you know?

Socket

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.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc