Skip to main content

PROperty DEfinitions

Project description

npm version License: Apache

prode.js

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

Installation

For usage within a javascript project:

npm install @exabyte-io/prode.js

For development:

git clone https://github.com/Exabyte-io/prode.js.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.10.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.10.post0-py3-none-any.whl (3.9 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: mat3ra_prode-2025.11.10.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.10.post0.tar.gz
Algorithm Hash digest
SHA256 af2e59a401553b87ea48e5981094067ecdcc14985156327fe5619c46d199d9c8
MD5 46cfa416e09eecd63bc49dfc1eb54099
BLAKE2b-256 02e552bb92741000129833106bd9fcd6139ea4c1d636f0a9070a2f590dc9cd0c

See more details on using hashes here.

File details

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

File metadata

  • Download URL: mat3ra_prode-2025.11.10.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.10.post0-py3-none-any.whl
Algorithm Hash digest
SHA256 f158fa64474550e5f40565b048f1fd1e6d1d4a1426972bfffe5dd6bfb86eb237
MD5 d69f95ce790a181aab0352517fb4280a
BLAKE2b-256 599d782195c32c2fae0658cf8da4eaab4b010eff0246b187072ed78bdfb3cbb5

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