Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/ndyag/anki-apkg

Create .apkg file for Anki
https://github.com/ndyag/anki-apkg

anki

Last synced: 4 days ago
JSON representation

Create .apkg file for Anki

Awesome Lists containing this project

README

        

# anki-apkg

anki-apkg is highly inspired by [anki-apkg-export](https://github.com/repeat-space/anki-apkg-export/) and works almost the same, then why a new package?

Because I'm not satisfied with only creating `{{front}}` and `{{back}}` field for a card, this package is created to make it possible to customize fields (and any other variables of a deck or card in the future).

```
npm install anki-apkg
```

```js
const { APKG } = require('anki-apkg')

const apkg = new APKG({
name: 'VocabularyBuilder',
card: {
fields: ['word', 'meaning', 'usage'],
template: {
question: '{{word}}',
answer: `

{{word}}

{{meaning}}

{{usage}}

`
},
styleText: '.card { text-align: center; }'
}
})
apkg.addCard({
timestamp: +new Date(), // create time
content: ['sample word', 'sample meaning', 'sample usage'] // keep the order same as `fields` defined above
})
apkg.save(__dirname)
```

## Media

You can add media files to packages using
```ts
apkg.addMedia(filename: string, data: Buffer)
```

```js
const { readFileSync } = require('fs')
const { join } = require('path')

const { APKG } = require('../')

const apkg = new APKG({
name: 'UnicornBuilder',
card: {
fields: ['question', 'result'],
template: {
question: '{{question}}',
answer: `{{result}}`
}
}
})
apkg.addCard({
content: ['What happens if you eat too many skittles?', '']
})
apkg.addMedia('unicorn.gif', readFileSync(join(__dirname, 'media/unicorn.gif')))
apkg.save(__dirname)

```