Skip to content
React components library that implement Lalamove Design.
JavaScript Other
Branch: master
Clone or download

Latest commit

Fetching latest commit…
Cannot retrieve the latest commit at this time.


Type Name Latest commit message Commit time
Failed to load latest commit information.
.stylelintrc UPT: Update documentation Sep 17, 2019
renovate.json UPT: Update config Sep 4, 2019


React components library that implement Lalamove Design, for building products on the web.

📦 Install

Please make sure you install the following dependencies:

    "downshift": "^3.3.1",
    "moment": "^2.24.0",
    "polished": "^3.4.1",
    "prop-types": "^15.7.2",
    "react": "^16.9.0",
    "react-dates": "^21.5.0",
    "react-dom": "^16.9.0",
    "react-tooltip": "^3.11.1",
    "styled-components": "^4.3.2"

And run the following:

yarn add @lalamove/karang

You may check on our Github Releases page for the version releases.

👩🏻‍💻 Usage

Initialize the library at the top level

You must first initialize the library in order to set configuration globals.

First, please embed the required fonts into your application, for example, you can copy the following code into the <head> element of your web app.

<link rel="stylesheet" href=",700" />
<link rel="stylesheet" href="" />

At the top level of your application, instantiate a BaseApp component and pass the rest of your application as its children.

import React from 'react';
import { BaseApp } from '@lalamove/karang';

const App = () => (

export default App;

Using exported UI components

Quick example to get you started in your own components:

import React, { Fragment } from 'react';
import { Radio } from '@lalamove/karang';

const MyComponent = () => (
    <Radio name="payment" value="cash">
      Radio 1

export default MyComponent;

We also support partial import for smaller build:

import Radio from '@lalamove/karang/dist/components/Radio';

Right-to-left (RTL) support

All components support right-to-left layout used in languages such as Arabic, Hebrew, and Persian. In order to flip the direction of components, follow these procedure:

Set the HTML attribute dir to rtl on the root element of your application, for example the body:

<body dir="rtl">

On the BaseApp component that you have instantiated at the top level of your application, set rtl props to true:

const App = () => (
  <BaseApp rtl>

Visit our Storybook page for RTL demos.

👷🏻‍♀️ Contributing to karang

Configure your editor

To enable stylelint for styled-components, configure your editor to have stylelint watch .js files.

Sublime Text

"stylelint": {
  "selector": "source.js"

Visual Studio Code

"stylelint.additionalDocumentSelectors": [

WebStorm or other JetBrains IDEs

Install Styled Components plugin in IDE Preferences | Plugins.

Develop with storybook

Run the following commands for development:

yarn storybook ## Start development with Storybook
yarn doc ## Styleguide and usage
yarn test ## Run test
yarn lint:js ## Lint the JavaScript files
yarn lint:css ## Lint the CSS files including styled-components
yarn build ## Build all of the JavaScript files using Babel

Remember to export your components in src/index.js.

This project is maintained by Lalamove. Please read through our contributing guidelines for the contribution.

📄 License

Copyright © 2019 Lalamove. Code released under the MIT License.

You can’t perform that action at this time.