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.
carbon/lib/api.js

68 lines
1.6 KiB
JavaScript

import axios from 'axios'
const DOMAIN = process.browser ? document.location.origin : ''
const gistClient = axios.create({
baseURL: 'https://api.github.com',
timeout: 5000,
headers: {
Accept: 'application/vnd.github.v3+json',
'Content-Type': 'application/json'
}
});
async function tweet (encodedImage) {
const processedData = encodedImage.split(',')[1]
return axios.post(`${DOMAIN}/twitter`, { data: processedData })
.then((res) => res.data.url)
.then((url) => encodeURIComponent(`Built with @carbon ${url}`))
.then((uri) => `https://twitter.com/intent/tweet?text=${uri}`)
.then(openTwitterUrl)
}
async function uploadImage (encodedImage) {
// upload image
const url = 'https://api.imgur.com/3/image'
const data = new FormData()
data.append('image', encodedImage)
data.append('type', 'image/png')
const config = {
headers: {
Authorization: `Client-ID 87cc98dcdabcbb3`
}
}
return axios.post(url, data, config)
.then(res => res.data)
.catch(console.log)
}
const getGist = (id) => {
const uid = id.split('/').pop()
return gistClient.get(`/gists/${uid}`)
.then(res => res.data)
.then(gist => gist.files)
.then(files => files[Object.keys(files)[0]])
.then(file => file.content)
}
export default {
uploadImage,
getGist,
tweet
}
// private
function openTwitterUrl (twitterUrl) {
const width = 575, height = 400
const left = (window.outerWidth - width) / 2
const right = (window.outerHeight - height) / 2
const opts = `status=1,width=${width},height=${height},top=${top},left=${left}`
window.open(twitterUrl, 'twitter', opts)
}