Skip to content

Latest commit

 

History

History
184 lines (139 loc) · 3.58 KB

README.md

File metadata and controls

184 lines (139 loc) · 3.58 KB

🦫 Alkstore

Alkstore is a simple, fast and awesome state container for your JavaScript apps.

It is mainly inspired by redux but it's lighter and simpler.

Installation

npm install alkstore
or
yarn add alkstore
or
pnpm add alkstore

Getting started

  1. Define initial state
// initial-state.ts
export const initialState = {
  count: 0,
  name: 'John',
  isOnline: false,
};

export type RootState = typeof initialState;
  1. Define actions
// actions.ts
export function incrementCount(incrementValue = 1) {
  return { type: 'increment', payload: { count: incrementValue } };
}

export function decrementCount(decrementValue = 1) {
  return { type: 'decrement', payload: { count: decrementValue } };
}

export function resetCount(reset = 0) {
  return { type: 'reset', payload: { count: reset } };
}
  1. Define reducer
// reducers.ts
import { combineReducers } from 'alkstore';
import type { Action, Reducers } from 'alkstore';

import { RootState } from './initial-state';

const countReducer: Reducers<RootState, Action<RootState>> = {
  increment(state, action) {
    return {
      ...state,
      count: action.payload.count ? state.count + action.payload.count : state.count,
    };
  },
  decrement(state, action) {
    return {
      ...state,
      count: action.payload.count ? state.count - action.payload.count : state.count,
    };
  },
  reset(state, action) {
    return {
      ...state,
      count: action.payload.count ?? 0,
    };
  },
};

const reducers = combineReducers<RootState>(countReducer);
  1. Create store and provide app with it
// index.ts
import React from 'react';
import ReactDOM from 'react-dom/client';

import { AlkstoreProvider, createStore } from 'alkstore';
import { initialState, reducers, RootState } from './store';

import App from './App';

const store = createStore<RootState>({
  initialState,
  reducers,
});

ReactDOM.createRoot(document.getElementById('root') as HTMLElement).render(
  <React.StrictMode>
    <AlkstoreProvider<RootState> store={store}>
      <App />
    </AlkstoreProvider>
  </React.StrictMode>,
);
  1. Use store in your app
// app.tsx
import { useSelector } from 'alkstore';

import { useAppDispatch, selectCount, decrementCount, incrementCount, resetCount } from './store';

function App() {
  const dispatch = useAppDispatch();
  const count = useSelector(selectCount);

  return (
    <div>
      <p>
        You have clicked the button
        <strong> {count}</strong> times.
      </p>

      <div>
        <button onClick={() => dispatch(incrementCount())}>Increment</button>
        <button onClick={() => dispatch(decrementCount())}>Decrement</button>
        <button onClick={() => dispatch(resetCount())}>Reset</button>
      </div>
    </div>
  );
}

export default App;

Prerequisites in development mode

  • In order to run the application, you need to have installed pnpm.
npm install -g pnpm

Start using development mode

  1. Clone repository and install dependencies
git clone alkstore
cd alkstore
pnpm install
  1. Go to example folder and install dependencies
cd example
pnpm install
  1. Run example
pnpm dev

In development mode you can run the following commands

alkstore

  • pnpm build - build alkstore package
  • build:esm - build esm modules
  • build:cjs - build cjs modules
  • pnpm lint - run linter
  • pnpm test - run tests

alkstore/example

  • pnpm dev - run example app in development mode
  • pnpm build - build example app
  • pnpm preview - preview production build