nfp_sites/api/media/model.mjs

70 lines
1.2 KiB
JavaScript
Raw Normal View History

2019-02-20 16:10:37 +00:00
import path from 'path'
2019-09-14 19:03:38 +00:00
import bookshelf from '../bookshelf.mjs'
import config from '../config.mjs'
2019-02-20 16:10:37 +00:00
/*
Media model:
{
filename,
filetype,
small_image,
medium_image,
large_image,
*small_url,
*medium_url,
*large_url,
size,
staff_id,
is_deleted,
created_at,
updated_at,
}
*/
const Media = bookshelf.createModel({
tableName: 'media',
virtuals: {
small_url() {
return `${Media.baseUrl}${this.get('small_image')}`
},
medium_url() {
return `${Media.baseUrl}${this.get('medium_image')}`
},
large_url() {
return `${Media.baseUrl}${this.get('large_image')}`
},
2019-09-13 13:33:10 +00:00
link() {
return `${Media.baseUrl}${this.get('org_image')}`
2019-09-13 13:33:10 +00:00
},
url() {
2019-10-01 03:45:44 +00:00
return `${Media.baseUrl}${this.get('medium_image')}`
2019-09-13 13:33:10 +00:00
},
thumb() {
return `${Media.baseUrl}${this.get('small_image')}`
},
2019-02-20 16:10:37 +00:00
},
}, {
2019-09-14 19:03:38 +00:00
baseUrl: config.get('upload:baseurl'),
2019-02-20 16:10:37 +00:00
getSubUrl(input, size) {
if (!input) return input
let output = input
if (path.extname(input)) {
let ext = path.extname(input).toLowerCase()
output = input.slice(0, -ext.length)
}
return `${output}.${size}.jpg`
},
})
export default Media