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

@anephenix/ui

Package Overview
Dependencies
Maintainers
1
Versions
35
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@anephenix/ui

A collection of UI components for React web applications

  • 0.0.26
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
0
decreased by-100%
Maintainers
1
Weekly downloads
 
Created
Source

UI

A design system for Next.js applications, using Sass as the CSS preprocessor.

CircleCI Coverage Status

Installation

npm i @anephenix/ui --save

Dependencies

  • Node.js (12)
  • React (Version 16)
  • Sass Lang (recommend installing @zeit/next-sass if using with Next.js)

Setup

In order to use Anephenix's React UI within your applications, you will need to do 2 things:

1 - Adjust your Webpack configuration in order to load the react components and compile them with sass as the CSS preprocessor. 2 - Wrap your React app in a higher-order-component in order to inherit the theme for the design system.

Step 1

Make sure that the next.config.js file for your Next.js app has this code:

const path = require('path');
const withSass = require('@zeit/next-sass');

const applyWebpackConfig = (test = /\.jsx/) => {
	return (config, options) => {
		config.module.rules.push({
			test,
			use: [options.defaultLoaders.babel],
		});
		return config;
	};
};

module.exports = withSass({
	sassLoaderOptions: {
		sassOptions: {
			includePaths: [path.resolve('node_modules')],
		},
	},
	webpack: applyWebpackConfig(),
});

The sassLoader options configuration allows next-sass to compile the CSS from files that are sourced from the node_modules folder. The applyWebpackConfig function ensures that you can load the React components from the node_modules folder.

By default, applyWebpackConfig will look for .jsx files in the @anephenix/ui npm package.

Step 2

In your pages/_app.js file, wrap the page components with a <Theme> component, like in the example below:

import App from 'next/app';
import React from 'react';
import Head from 'next/head';
import { Theme } from '@anephenix/ui';

class MyApp extends App {
	render() {
		const { Component, pageProps } = this.props;
		return (
			<>
				<Head>
					<meta
						name="viewport"
						content="initial-scale=1.0, width=device-width"
					/>
					<title>My App</title>
				</Head>
				<Theme>
					<Component {...pageProps} />
				</Theme>
			</>
		);
	}
}
export default MyApp;

The <Theme> component is a higher order component that ensure that the Sass files are loaded that apply global styling rules for the design system.

Usage

To be fleshed out. See the site for details.

tests

npm t

License and credits

©2020 Anephenix OÜ. UI is licenced under the MIT Licence.

Keywords

FAQs

Package last updated on 25 Jan 2021

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