npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@noths/global-components

v3.4.8

Published

A set of global components for NOTHS.

Downloads

66

Readme

NOTHS Global Components

npm version Depfu Depfu

Frontend global components used at www.notonthehighstreet.com

Components included

  • NOTHS Header
  • NOTHS Footer
  • NOTHS Copyright statement
  • NOTHS Navigation and Mega Dropdown

Background & context

Global components are components which will be on most pages of the site.

These components use mainly vanilla javascript and do not use any framework. This is to reduce the footprint on the consuming application.

The components are written in ES2015 and use Webpack for compilation and minification.

Component usage

Consuming

HTML

The NPM module includes pre bundled HTML files for Header, Footer and Copyright components. To include these copy the file contents from node_modules/@noths/global-components/compiled/dist/[header|footer|copyright].html and insert into your page where required.

React

import React from 'react';
import { Header, Footer, Copyright } from '@noths/global-components';

export class App extends React.Component {
  render() {
    return (
      <div id="app">
        <Header />
          <h1>hello world</h1>
        <Footer />
        <Copyright />
      </div>
    );
  }
}

NOTE: These components are created using dangerouslySetInnerHTML of their counterpart HTML component. There is no JS logic in them, it's simply a wrapper to aid integrating components into React apps.

Consuming statically

React

To avoid having multiple verbose imports use the babel import plugin to rewrite them:

import Footer from '@noths/global-components/compiled/static/react/footer';
import Header from '@noths/global-components/compiled/static/react/header';
// becomes
import { Header, Footer } from '@noths/global-components';

Setup the babel import plugin:

// Install the plugin
npm install babel-plugin-import

// Add the following import config (you may have to update your .babelrc file to .babelrc.js):
module.exports = {
  ...
  plugins: [
    ...
    [
      'import',
      {
        libraryName: '@noths/global-components',
        libraryDirectory: 'compiled/static/react'
      },
    ],
  ],
};

The following functions are available as helpers to get the CDN path for the static stylesheet and script files:

globalsUrls(env) [development, qa, staging, oldstaging, production]

Returns the global static files CDN URLs for that environment (globally shared across services e.g. css resets etc.)

import { globalsUrls } from '@noths/global-components/helpers/static-files';

<html>
  <head>
    <link rel="stylesheet" type="text/css" href={globalsUrls(process.env.NODE_ENV).css} />
    ...
  </head>
</html>;

globalComponentsUrls(env) [development, qa, staging, oldstaging, production]

Returns the static files CDN URLS for the environment that includes all the components in a single bundle.

import { globalComponentsUrls } from '@noths/global-components/helpers/static-files';

<html>
  <head>
    <link rel="stylesheet" type="text/css" href={globalComponentsUrls(process.env.NODE_ENV).css} />
  </head>
  <body>
    ...
    <script src={globalComponentsUrls(process.env.NODE_ENV).js} />
  </body>
</html>;

Usage example with a Next.js app:

// _document.js
import Document, { Head, Main, NextScript } from 'next/document';
import { globalsUrls, globalComponentsUrls } from '@noths/global-components/helpers/static-files';

const env = process.env.NODE_ENV;
export default class ExtendedDoc extends Document {
  render() {
    <html>
      <Head>
        <link
          rel="stylesheet"
          type="text/css"
          href={globalsUrls(env).css}
        />
        <link
          rel="stylesheet"
          type="text/css"
          href={globalComponentsUrls(env).css}
        />
        ...
      </Head>
      <body>
        <Header />
        <Main />
        <Footer />
        <Copyright />
        <NextScript />
        ...
        <script src={globalComponentsUrls(env).js} />
      </body>
    </html>;
  }
}

_NOTE: These components are created using `dangerouslySetInnerHTML` of their counterpart HTML component. There is no JS logic in them, it's simply a wrapper to aid integrating components into React apps._

#### No framework

The NPM module includes pre bundled HTML, CSS and JS static files for the Header, Footer and Copyright components.

```js
// HTML
'node_modules/@noths/global-components/compiled/static/html/[header|footer|copyright].html';

// CSS & JS
'node_modules/@noths/global-components/compiled/static/css/global.css';
'node_modules/@noths/global-components/compiled/static/[css|js]/all-components.[css|js]';

Triggering the Mobile Navigation

The Header components handles triggering the Mobile navigation when the burger menu is click by default. But if you need to toggle the Mobile navigation from another element you will need to fire a TOGGLE_NAVIGATION event.

Here is an example:

  const event = document.createEvent('Event');
  event.initEvent('TOGGLE_NAVIGATION', true, true):
  document.dispatchEvent(event);

Installation

Prerequisites

  • NodeJS 8

Setup & run

Install dependencies

npm install

Build and start

npm run build_and_start

Build and start for development which will watch your files and rebuild if there are any changes.

npm run watch

Testing

There are two different types of tests in the project.

Unit tests

Unit tests use Mocha and Chai.

To run unit tests:

npm run test
npm run test:build // Ensure npm run build is run beforehand

End to end tests (e2e)

End to end tests use cypress.

To run e2e tests:

npm run test:features

There may be cases where feature tests runs fine locally but not in CircleCI. In order to debug the failing CI test(s), we can store cypress screenshots and videos as CircleCI artifacts. This store_artifact step is not a part of this repo's circleci/config.yml so screenshots are not stored as artifacts by default. To get this feature, maually add the store_artifacts steps as below in the features section of Configuration File i.e config.yml. Configuration File could be accessed by tapping on the ... dots on each pipeline build.

  - store_artifacts:
      path: packages/global-components/cypress/videos
  - store_artifacts:
      path: packages/global-components/cypress/screenshots

After adding the above lines, do commit and save and rerun the build. At the end of the build process, click on features job from the status and the screenshots and the videos can be accessed from the Artifacts tab.

Mocks

There are a number of API's that get mocked as part of the e2e tests. Theses mocks are stored in server/dev-mocks.js.

Releases

The project is hosted on NPM with the name @noths/global-components.

To Publish a Beta Package

npm run build

npm run publish:beta

To upload static files to S3: in AWS S3 console, select the buckets for qa-static-files/frontend-packages/global-components. Create a new folder with the version number that matches the beta package number just generated. Then upload the javascript and css files that have been generated locally in the dist/static folder.

TODO

  • Still using styles-toolkit even though the repo has been deprecated and deleting
  • No support for static assets i.e. pushing images to a CDN