A module for cleaning up artist, album, and song names.
npm install @web-scrobbler/metadata-filterA module for cleaning up artist, album, and song names.
```
npm i @web-scrobbler/metadata-filter
`html`
If you want to use this module in a project which is built with a bundler (e.g.
webpack), you can use CommonJS-like or ES6 imports:
`javascript
// CommonJS style
const MetadataFilter = require('@web-scrobbler/metadata-filter');
// ES6 style
import * as MetadataFilter from '@web-scrobbler/metadata-filter';
MetadataFilter.removeRemastered(yourInput);
`
In a browser you can access to the module by using the global MetadataFilter
object:
`html`
You can call filter functions for basic, one-line filter functionality.
These filter functions are intended to be used on a single field, such as
an artist, album, or track.
However, it is possible (not officially supported) to use some of these on
combined fields ("Artist - Song", "Artist - Album"), as in the third example below.
`javascript`
console.log(MetadataFilter.removeRemastered('Jane Doe (Remastered)')); // Jane Doe
console.log(MetadataFilter.removeVersion('Get Lucky (Album Version)')); // Get Lucky
console.log(
MetadataFilter.youtube(
'Car Bomb - Scattered Sprites (Official Music Video)'
)
); // Car Bomb - Scattered Sprites
See src/functions.ts for more details.
You can also use multiple filter functions on a string at once by creating a
MetadataFilter object which combines multiple functions from above,
or by using one of the pre-existing filter objects.
First, create a filter set. This is a set of filter functions for different
fields.
`javascript`
const filterSet = {
track: [
MetadataFilter.removeRemastered,
MetadataFilter.fixTrackSuffix,
MetadataFilter.removeLive,
],
album: [
MetadataFilter.removeRemastered,
MetadataFilter.fixTrackSuffix,
MetadataFilter.removeLive,
],
};
Then, construct a MetadataFilter using this filter set.
`javascript`
const filter = MetadataFilter.createFilter(filterSet);
console.log(filter.filterField('album', 'Nevermind (Remastered)')); // Nevermind
console.log(filter.filterField('track', 'In Bloom - Nevermind Version')); // In Bloom (Nevermind Version)
There are also predefined filters available for easy access. For example,
the above filter set can be acquired using createSpotifyFilter() function:
`javascript`
const filter = MetadataFilter.createSpotifyFilter();
See src/filters.ts for more details.
Finally, you can take existing MetadataFilter objects and extend them with another filter..extend()
This is done by providing the method with another MetadataFilter object.
`javascript
const filter = MetadataFilter.createSpotifyFilter();
filter.extend(MetadataFilter.createAmazonFilter());
// This would also work: filter.extend(MetadataFilter.createFilter(filterSet));
console.log(
filter.filterField('track', 'Seasons in the Abyss (Album Version)')
); // Seasons in the Abyss
`
As an alternative, you can use the .append() method to apply a filter set toMetadataFilter
an existing object.
`javascript
const filter = MetadataFilter.createFilter({ track: filterTrack });
filter.append({ artist: filterArtist });
`
Since these methods return a MetadataFilter instance, you can chain method calls.
`javascript`
const filter = MetadataFilter.createFilter({ track: filterTrack }).append({
artist: filterArtist,
});
`shInstall dev dependencies
> npm install
- [music-metadata-filter] - Python implementation of this module
Licensed under the MIT License.
[workflow-badge]: https://img.shields.io/github/actions/workflow/status/web-scrobbler/metadata-filter/test.yml
[npm-badge]: https://img.shields.io/npm/v/@web-scrobbler/metadata-filter
[codacy-badge]: https://img.shields.io/codacy/grade/100b50dc21664ce6bc591c28b73d6892
[coverage-badge]: https://img.shields.io/codacy/coverage/100b50dc21664ce6bc591c28b73d6892
[codacy]: https://app.codacy.com/gh/web-scrobbler/metadata-filter/dashboard
[npm]: https://www.npmjs.com/package/@web-scrobbler/metadata-filter
[workflow]: https://github.com/web-scrobbler/metadata-filter/actions/workflows/test.yml
[music-metadata-filter]: https://github.com/djmattyg007/music-metadata-filter