Git Product home page Git Product logo

launch-solid-ui's Introduction

Welcome to Launch UI - Solid JS Version

A UI library containing a set of beautiful Solid JS components.

Storybook available at launch-ui.netlify.app.

Installation

npm install @launch/solid
# or
yarn add @launch/solid

Prerequisites

  • yarn The project uses yarn over alternatives such as NPM/PNPM/...
  • node

Clone & Setup

Clone the repository to your local machine.

$ git clone [email protected]:launch-ai/launch-ui.git

Install dependencies & git hooks.

$ yarn install

Run the storybook.

$ yarn run storybook

Styling

Styling is done with Emotion and twin.macro using a custom styled util.

Example:

import tw from 'twin.macro'
import { styled } from './src/utils/styled'

type ButtonProps = { block: boolean }

type StyledButtonProps = ButtonProps

const baseStyles = tw`border border-black px-4 py-2`

const blockStyles = ({ block }: StyledButtonProps) => block && tw`block w-full`

const StyledButton = styled('button')<StyledButtonProps>(
  baseStyles,
  blockStyles,
)

const Button: Component<ButtonProps> = (props) => {
  return (
    <StyledButton block={props.block}>
      {props.children}
    </StyledButton>
  )
}

export default Button

Commit messages

Conventional Commits is used for all commit messages with the AngularJS variation.

This is enforced by a pre-commit hook with commitlint. If your commit message does not meet the conventional commits standard, the commit hook will fail. This helps with generating changelogs with version updates.

In summary, the commit message header has the following format:

<type>(<scope>): <short summary>
  โ”‚       โ”‚             โ”‚
  โ”‚       โ”‚             โ””โ”€โซธ Summary in present tense. Not capitalized. No period at the end.
  โ”‚       โ”‚
  โ”‚       โ””โ”€โซธ Commit Scope: products|orders|settings|...
  โ”‚
  โ””โ”€โซธ Commit Type: build|ci|docs|feat|fix|perf|refactor|test

The commit type must be one of the following:

  • build: Changes that affect the build system or external dependencies (example scopes: gulp, broccoli, npm)
  • ci: Changes to our CI configuration files and scripts (example scopes: Circle, BrowserStack, SauceLabs)
  • docs: Documentation only changes
  • feat: A new feature
  • fix: A bug fix
  • perf: A code change that improves performance
  • refactor: A code change that neither fixes a bug nor adds a feature
  • test: Adding missing tests or correcting existing tests

Pre-commit Hooks

Husky and lint-staged is used for pre-commit git hooks.

When you execute a commit, the following commands will be executed:

  • Lint staged files:

    npx lint-staged

  • Validate commit message:

    npx --no-install commitlint --edit ""

The configuration can be found in .husky/pre-commit and in package.json under "lint-staged".

Additional hooks can be added with:

npx husky add .husky/pre-commit "yarn test"

launch-solid-ui's People

Contributors

tqwewe avatar 0xpranavdoshi avatar vishvadlamani avatar suptejas avatar

Watchers

James Cloos avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.