2.0.8 • Published 1 year ago

@ribon.io/shared v2.0.8

Weekly downloads
-
License
Apache-2.0
Repository
github
Last release
1 year ago

@ribon.io/shared

Small library used to share resources between our frontends

Usage:

  • Install via yarn
    yarn add @ribon.io/shared
- Import and use whatever you want!
```js
import { defaultDisplayLarge, theme } from '@ribon.io/shared/styles';
import { useNonProfits } from '@ribon.io/shared/hooks';

export const Title = styled.h1`
      ${defaultDisplayLarge};
      color: ${({ theme }) => theme.colors.green30};
      font-weight: ${({ theme }) => theme.font.light};
`;

// in a component (check setup hooks for using api hooks)
function MyComponent() {
  const { nonProfits, loading, error } = useNonProfits();
  // ...
}

Setup hooks:

@ribon.io/shared lib uses the react-query lib to make caches of api calls. In order to use the hooks you need to wrap your app with the QueryClientComponent component:

import { QueryClientComponent } from "@ribon.io/shared/hooks";

function App() {
  return (
    <QueryClientProvider>
        ...
    </QueryClientProvider>
  );
}

Developing locally:

  • Clone the repo:
git clone git@github.com:RibonDAO/shared.git  
  • Install dependencies
yarn

You can code and test directly in the project using the jest test runner. To run the tests:

yarn test

If you want to use the lib in another project, you can start the project (it will build the lib and watch for changes) and link it to the other project:

yarn start
cd dist
yarn link

Notice you need to link the dist folder, that is generated after the build process. Observation: This does not work with react-native (see more in here). You can check the section React Native Problems below to see how to use it on the mobile app.

Then in the project you want to test the changes:

yarn link @ribon.io/shared

This will link the local version of the lib to the project. Instead of using the @ribon.io/shared package from npm, it will use from your local machine. When you make changes to the @ribon.io/shared lib locally, it will be reflected in the project you are testing.

Publishing:

To make a new release, you need to bump the version in the package.json and create a new git tag for it. Use the npm version command:

npm version patch //(or other version type command)
git push -u origin main --tags // this will push the new github tag that is correspondent to the npm version

To deploy the new version, you have to create a new release in the github UI. There is a github action to automatically deploy to npm after a new github release is created.

Tips:

  • Normally, before creating a new hook, lib, api call or other resource, you can first create this on the project you are working with, and after if you see a necessity, you can move it to the shared lib. This way you can test it and see if it is really necessary to move it to the shared lib.

What can we share?

  • Types (entities, responses and enums)
  • Styles (theme and typography)
  • Hooks and services
  • Small libs (NOT IMPLEMENTED YET)

React-native problems

React-native doesn't recognize stylized typography (that one using the Gambarino font). So we need to use a different approach to load custom fonts on mobile frontends. It will be implemented until the end of 2022.

React-native doesn't support symlinks, so we cannot use yarn link to build locally. To develop locally, you can use the command yarn dev on the ribon-shared project and create a .env with the relative path to the mobile app project. Example:

RIBON_NATIVE_PATH=../native-dapp

It has to have the RIBON_NATIVE_PATH variable and a relative path from the ribon-shared directory. It will copy the dist folder to the mobile app project and you can use the local version of the lib.

2.0.8

1 year ago

2.0.5

1 year ago

2.0.7

1 year ago

2.0.6

1 year ago

2.0.3

1 year ago

2.0.2

1 year ago

2.0.4

1 year ago

2.0.1

1 year ago

2.0.0

1 year ago

1.1.82

1 year ago

1.1.81

1 year ago

1.1.80

1 year ago

1.1.79

1 year ago

1.1.70

1 year ago

1.1.74

1 year ago

1.1.73

1 year ago

1.1.72

1 year ago

1.1.71

1 year ago

1.1.77

1 year ago

1.1.76

1 year ago

1.1.75

1 year ago

1.1.59

1 year ago

1.1.58

1 year ago

1.1.63

1 year ago

1.1.62

1 year ago

1.1.61

1 year ago

1.1.60

1 year ago

1.1.66

1 year ago

1.1.65

1 year ago

1.1.69

1 year ago

1.1.68

1 year ago

1.1.57

1 year ago

1.1.56

1 year ago

1.1.55

1 year ago

1.1.54

1 year ago

1.1.53

1 year ago

1.1.51

1 year ago

1.1.50

1 year ago

1.1.49

1 year ago

1.1.48

1 year ago

1.1.47

1 year ago

1.1.46

2 years ago

1.1.45

2 years ago

1.1.44

2 years ago

1.1.43

2 years ago

1.1.41

2 years ago

1.1.40

2 years ago

1.1.42

2 years ago

1.1.39

2 years ago

1.1.38

2 years ago

1.1.37

2 years ago

1.1.36

2 years ago

1.1.34

2 years ago

1.1.33

2 years ago

1.1.32

2 years ago

1.1.35

2 years ago

1.1.30

2 years ago

1.1.31

2 years ago

1.1.29

2 years ago

1.1.28

2 years ago

1.1.27

2 years ago

1.1.26

2 years ago

1.1.25

2 years ago

1.1.24

2 years ago

1.1.22

2 years ago

1.1.21

2 years ago

1.1.20

2 years ago

1.1.19

2 years ago

1.1.18

2 years ago

1.1.17

2 years ago

1.1.16

2 years ago

1.1.15

2 years ago

1.1.14

2 years ago

1.0.77

2 years ago

1.0.76

2 years ago

1.0.75

2 years ago

1.0.74

2 years ago

1.0.79

2 years ago

1.0.78

2 years ago

1.1.1

2 years ago

1.1.0

2 years ago

1.1.9

2 years ago

1.1.8

2 years ago

1.1.7

2 years ago

1.1.6

2 years ago

1.1.4

2 years ago

1.1.3

2 years ago

1.1.12

2 years ago

1.1.11

2 years ago

1.1.10

2 years ago

1.1.13

2 years ago

1.0.80

2 years ago

1.0.84

2 years ago

1.0.83

2 years ago

1.0.82

2 years ago

1.0.81

2 years ago

1.0.88

2 years ago

1.0.87

2 years ago

1.0.86

2 years ago

1.0.89

2 years ago

1.0.91

2 years ago

1.0.90

2 years ago

1.0.95

2 years ago

1.0.94

2 years ago

1.0.93

2 years ago

1.0.73

2 years ago

1.0.62

2 years ago

1.0.61

2 years ago

1.0.60

2 years ago

1.0.66

2 years ago

1.0.65

2 years ago

1.0.64

2 years ago

1.0.63

2 years ago

1.0.69

2 years ago

1.0.68

2 years ago

1.0.72

2 years ago

1.0.71

2 years ago

1.0.70

2 years ago

1.0.55

2 years ago

1.0.54

2 years ago

1.0.53

2 years ago

1.0.52

2 years ago

1.0.59

2 years ago

1.0.58

2 years ago

1.0.57

2 years ago

1.0.56

2 years ago

1.0.37

3 years ago

1.0.39

3 years ago

1.0.38

3 years ago

1.0.40

3 years ago

1.0.44

3 years ago

1.0.43

3 years ago

1.0.42

3 years ago

1.0.41

3 years ago

1.0.48

3 years ago

1.0.47

3 years ago

1.0.46

3 years ago

1.0.45

3 years ago

1.0.49

3 years ago

1.0.51

2 years ago

1.0.50

3 years ago

1.0.29

3 years ago

1.0.28

3 years ago

1.0.27

3 years ago

1.0.33

3 years ago

1.0.32

3 years ago

1.0.30

3 years ago

1.0.36

3 years ago

1.0.35

3 years ago

1.0.34

3 years ago

1.0.26

3 years ago

1.0.25

3 years ago

1.0.24

3 years ago

1.0.23

3 years ago

1.0.22

3 years ago

1.0.21

3 years ago

1.0.20

3 years ago

1.0.19

3 years ago

1.0.17

3 years ago

1.0.16

3 years ago

1.0.14

3 years ago

1.0.12

3 years ago

1.0.11

3 years ago

1.0.10

3 years ago

1.0.9

3 years ago

1.0.8

3 years ago

1.0.7

3 years ago

1.0.6

3 years ago

1.0.5

3 years ago

1.0.4

3 years ago

1.0.3

3 years ago

1.0.2

3 years ago

1.0.1

3 years ago