Skip to content

Latest commit

 

History

History
133 lines (90 loc) · 4.57 KB

README.md

File metadata and controls

133 lines (90 loc) · 4.57 KB


API Docs

The official the Framer Library documentation. It’s a curated site that can pull in documentation from the TSDoc comments in the project source. The foundation of the site is built on top of Monobase. You can see the published website at framer.com/api/

Contributing

If you're interested in contributing documentation check Contributing for more details on adding and updating content. For hacking on the api-docs project itself read on.

Installation

Clone the repository and install the dependencies:

% git clone [email protected]:framer/api-docs.git
% cd api-docs
% make bootstrap

Structure

.
├── Makefile            # Build Scripts
├── api                 # All files releated to generating framer.data.ts
├── components          # Holds all React components
│   ├── Navigation.tsx  # The main site navigation
│   ├── Template.tsx    # The main site template
│   ├── contexts        # React contexts
│   ├── documentation   # Components for displaying documentation from source code
│   ├── bootstrap.ts    # Contains JavaScript to be run on page load, e.g. syntax highlighting.
│   ├── framer.data.ts  # JSON data backing the documentation components
│   ├── index.tsx       # Exports components for use in pages
│   └── layout          # Components related to the site layout
├── pages               # Holds mdx & tsc files representing the page structure of the site
├── static              # Contains any static assets such as images.

Development

A development server can be started by running:

% make serve

This will watch for changes to the project files and reload the page when modified.

Testing

We use jest for our unit tests, these are mostly focused around the code used to generate the framer.data.ts file in the api directory. Though test for other parts of the codebase are most welcome.

To run the test suite:

% yarn jest

This will also be run by CircleCI on each commit and open Pull Request. CircleCI will also make a rudimentary check for missing models referenced by the API docs. The build output will contain logs with the broken reference ids.

Submitting Changes

Push changes up to a new branch in a fork of the api-docs repository (core team members can push directly to this repository) and open a Pull Request describing the changes.

Deployment

Deployment is managed by Netlify. On each commit to the master branch Netlify will rebuild changes and publish. Netlify will also generate a build for any pull requests created and add a link via the comments. The netlify.toml file contains the build and routing configuration for Netlify.

To invoke a manual build you can run:

% make build

This will output the static HTML/CSS and JavaScript into a build directory in the project root.

Framer API Data

The project makes use of the framer.api.json file bundled with each release of the "framer" and "framer-motion" packages. Both of these packages are installed as dependencies and we currently always track the latest release.

in the FramerStudio repository from this we extract the useful information used by our Framer API components. This is then transformed into a framer.data.ts package that is used by the <FramerAPIContext> component.

A FramerAPI class is available that provides lookup methods for querying the TypeScript API.

Example:

const scrollComponent = api.queryClass("Scroll")
console.log(scrollComponent.name)
console.log(scrollComponent.methods)
console.log(scrollComponent.properties)

The interfaces for these objects are defined in api/types.ts.

To regenerate the JSON data run:

% make data

If the API docs become out of date run:

% make data-update

By default make data will use the "framer" and "framer-motion" packages installed under node_modules. To reference a different install of either of these packages you can provide paths to make:

% make data FRAMER_LIBRARY_DIR=../some/path/to/Library FRAMER_MOTION_DIR=../some/path/to/motion