Skip to main content

PROperty DEfinitions

Project description

npm version License: Apache

prode

PROperty DEfinitions - prode - houses Property entity definitions for use in the Mat3ra platform.

Installation

For usage within a javascript project:

npm install @exabyte-io/prode

For development:

git clone https://github.com/Exabyte-io/prode.git

Contribution

This repository is an open-source work-in-progress and we welcome contributions.

We regularly deploy the latest code containing all accepted contributions online as part of the Mat3ra.com platform, so contributors will see their code in action there.

See ESSE for additional context regarding the data schemas used here.

Useful commands for development:

# run linter without persistence
npm run lint

# run linter and save edits
npm run lint:fix

# compile the library
npm run transpile

# run tests
npm run test

Using Linter

Linter setup will prevent committing files that don't adhere to the code standard. It will attempt to fix what it can automatically prior to the commit in order to reduce diff noise. This can lead to "unexpected" behavior where a file that is staged for commit is not identical to the file that actually gets committed. This happens in the lint-staged directive of the package.json file (by using a husky pre-commit hook). For example, if you add extra whitespace to a file, stage it, and try to commit it, you will see the following:

  repo-js git:(feature/cool-feature)  git commit -m "Awesome feature works great" Preparing...
✔ Running tasks...
✖ Prevented an empty git commit!
✔ Reverting to original state because of errors...
✔ Cleaning up...

   lint-staged prevented an empty git commit.
  Use the --allow-empty option to continue, or check your task configuration

husky - pre-commit hook exited with code 1 (error)

The staged change may remain but will not have been committed. Then it will look like you still have a staged change to commit, but the pre-commit hook will not actually commit it for you, quite frustrating! Styling can be applied manually and fixed by running:

npm run lint:fix

In which case, you may need to then add the linter edits to your staging, which in the example above, puts the file back to identical with the base branch, resulting in no staged changes whatsoever.

ProDe

TheProDe package is central to many other entities in the Mat3ra workflow ecosystem, where ProDe houses entity definitions for:

  • Property - the basic definition of a property

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mat3ra_prode-2025.11.16.post0.tar.gz (132.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mat3ra_prode-2025.11.16.post0-py3-none-any.whl (3.9 kB view details)

Uploaded Python 3

File details

Details for the file mat3ra_prode-2025.11.16.post0.tar.gz.

File metadata

  • Download URL: mat3ra_prode-2025.11.16.post0.tar.gz
  • Upload date:
  • Size: 132.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/8.7.0 pkginfo/1.12.1.2 requests/2.32.5 requests-toolbelt/1.0.0 tqdm/4.67.1 CPython/3.10.13

File hashes

Hashes for mat3ra_prode-2025.11.16.post0.tar.gz
Algorithm Hash digest
SHA256 1e968348fb12ff86404c4a756d4bac8ca28083e41aaf41f9c273d3c1c5ea5858
MD5 39db8a7fa1b0d2b9d7295298b2654c92
BLAKE2b-256 3ac83508dea6088215f879c7db85ce1d3906b953c69193ec215085880bd636b1

See more details on using hashes here.

File details

Details for the file mat3ra_prode-2025.11.16.post0-py3-none-any.whl.

File metadata

  • Download URL: mat3ra_prode-2025.11.16.post0-py3-none-any.whl
  • Upload date:
  • Size: 3.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/8.7.0 pkginfo/1.12.1.2 requests/2.32.5 requests-toolbelt/1.0.0 tqdm/4.67.1 CPython/3.10.13

File hashes

Hashes for mat3ra_prode-2025.11.16.post0-py3-none-any.whl
Algorithm Hash digest
SHA256 3540c08f9050da081a5c199e53cee7d569727c9916854966defc5c99a44d8412
MD5 07e05847f00652fd1d81e9f992d4c7b6
BLAKE2b-256 31a03686e8776c4e951a59686f397c99ed5628fe8ca60cc2bd83ad7ca67b3a12

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page