mirror of https://github.com/jo/docuri.git
You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
ed9f5886e8 | 11 years ago | |
---|---|---|
test | 11 years ago | |
.gitignore | 11 years ago | |
.travis.yml | 11 years ago | |
README.md | 11 years ago | |
index.js | 11 years ago | |
package.json | 11 years ago |
README.md
docuri
Rich document ids for CouchDB.
type/id/subtype/index/version
eg movie/blade-runner/gallery-image/12/medium
Usage
Parse id string:
require('docuri').parse('mytype/myid/mysubtype/myindex/myversion');
// {
// type: 'mytype',
// id: 'myid',
// subtype: 'mysubtype',
// index: 'myindex',
// version: 'myversion'
// }
Build id string from object:
require('docuri').stringify({
type: 'mytype',
id: 'myid',
subtype: 'mysubtype',
index: 'myindex',
version: 'myversion'
});
// 'mytype/myid/mysubtype/myindex/myversion'
Change id string components:
require('docuri').merge('mytype/myid/mysubtype/myindex/myversion', {
type: 'my_new_type',
});
// 'my_new_type/myid/mysubtype/myindex/myversion'
Browser support
To use docid in your client-side application, browserify it like this:
browserify -s DocURI path/to/docuri/index.js > path/to/your/assets
Once added to your DOM, this will leave you with a global DocURI object for use in your e.g. Backbone Models/Collections.
Development
To run the unit tests:
npm test
For JShint:
npm run jshint
License
Copyright (c) 2014 Johannes J. Schmidt, null2 GmbH
Licensed under the MIT license.