Skip to content

A React component for browsing and interacting with hypermedia REST APIs

License

Notifications You must be signed in to change notification settings

Tarun-DXC/halstack-browser

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

13 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Halstack Browser

Halstack Browser is a React component that can be included in any React Web App and provides a visual mechanism to crawl and discover API resources and operations dynamically for hypermedia-based APIs. In contrary to other path-based approaches such as OpenAPI (where static specs are used to describe a list of pre-defined path resources and available operations) Halstack Browser allows both API consumers and producers work with auto-discoverable REST APIs just based on their implementations, without any spec. Thus, every time an API implementation changes, these updates will be automatically visible in Halstack Browser Web component without the need of importing or configuring any API spec.

Halstack Browser in Action

See this demo app using Halstack browser. Paste your hypermedia-based API endpoint and start browsing!

Use

Installation

npm install --save @diaas/hal-ui

Implementation example

// import the HalUI component
import HalUI from "@diaas/hal-ui";

// use the component in your app
<HalUI url={api_base_url} headers={headers_object} />

Properties

Name Type Default Description
url String None Required. This property contains the base url of your HAL API.
headers JSON Object None Contains an object with the headers to be sent to every request to the API.

Develop

In the first place, clone this repository.

git clone https://github.dxc.com/DIaaS/diaas-hal-ui.git

Local development is broken into two parts, related to the lib/example folders.

First, within the lib folder, run rollup to watch your src/ module and automatically recompile it into dist/ whenever you make changes.

cd lib
npm install
npm start # runs rollup with watch flag

The second part will be running the example/ create-react-app that's linked to the local version of your module.

# (in another tab)
cd example
npm install
npm start # runs create-react-app dev server

Now, anytime you make a change to your library in src/ or to the example app's example/src, create-react-app will live-reload your local dev server so you can iterate on your component in real-time.

License

See Halstack Browser License here

About

A React component for browsing and interacting with hypermedia REST APIs

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 93.9%
  • HTML 4.8%
  • CSS 1.3%