const config = require('./config.json')
const df = require('date-format')
const fs = require('fs')
const Gitlab = require('gitlab/dist/es5').default
const klaw = require('klaw-sync')
const path = require('path')
const api = new Gitlab({
token: config.token
})
const months = [
'January',
'February',
'March',
'April',
'May',
'June',
'July',
'August',
'September',
'October',
'November',
'December'
]
const year = new Date().getFullYear().toString()
const month = months[new Date().getMonth()]
if (!fs.existsSync(path.join(__dirname, year))) fs.mkdirSync(path.join(__dirname, year))
if (!fs.existsSync(path.join(__dirname, year, month))) fs.mkdirSync(path.join(__dirname, year, month))
const openedPath = path.join(__dirname, year, month, 'Opened')
const closedPath = path.join(__dirname, year, month, 'Closed')
if (!fs.existsSync(openedPath)) fs.mkdirSync(openedPath)
if (!fs.existsSync(closedPath)) fs.mkdirSync(closedPath)
let args = ''
for (const arg of process.argv) {
args += arg + ' '
}
if (!args.includes('--no-download')) download()
else createTable()
function download() {
api.Projects
.show('tildes/tildes')
.then((project) => {
api.Issues
.all({
projectId: project.id
})
.then((issues) => {
for (const issue of issues) {
if (new Date(issue.created_at).getMonth() === new Date().getMonth()) {
fs.writeFileSync(path.join(openedPath, issue.iid.toString()) + '.json', JSON.stringify(issue, null, 2))
}
if (new Date(issue.closed_at).getMonth() === new Date().getMonth()) {
fs.writeFileSync(path.join(closedPath, issue.iid.toString()) + '.json', JSON.stringify(issue, null, 2))
}
}
})
.then(createTable)
})
}
function createTable() {
let opened = klaw(openedPath)
let closed = klaw(closedPath)
opened.sort(function(a,b) {
const aFile = require(a.path)
const bFile = require(b.path)
return (aFile.iid > bFile.iid) ? 1 : ((bFile.iid > aFile.iid) ? -1 : 0)
})
closed.sort(function(a,b) {
const aFile = require(a.path)
const bFile = require(b.path)
return (aFile.iid > bFile.iid) ? 1 : ((bFile.iid > aFile.iid) ? -1 : 0)
})
let table = '## Issue Table\n'
table += '\n### Opened\n\n'
table += '| Issue | Title | Author | Opened | Closed |\n'
table += '| ----- | ----- | ------ | ------ | ------ |\n'
for (const file of opened) {
const issue = require(file.path)
table += `| ${issue.iid} |`
let title
if (issue.title.length >= 50) {
title = issue.title.substring(0, 47) + '...'
} else {
title = issue.title
}
table += ` ${title} |`
table += ` ${issue.author.username} |`
table += ` ${df.asString('yyyy/MM/dd hh:mm:ss', new Date(issue.created_at))} |`
let closedAt
if (issue.closed_at === null) {
closedAt = ''
} else {
closedAt = df.asString('yyyy/MM/dd hh:mm:ss', new Date(issue.closed_at))
}
table += ` ${closedAt} |\n`
}
table += '\n### Closed\n\n'
table += '| Issue | Title | Author | Opened | Closed |\n'
table += '| ----- | ----- | ------ | ------ | ------ |\n'
for (const file of closed) {
const issue = require(file.path)
table += `| ${issue.iid} |`
let title
if (issue.title.length >= 50) {
title = issue.title.substring(0, 47) + '...'
} else {
title = issue.title
}
table += ` ${title} |`
table += ` ${issue.author.username} |`
table += ` ${df.asString('yyyy/MM/dd hh:mm:ss', new Date(issue.created_at))} |`
let closedAt
if (issue.closed_at === null) {
closedAt = ''
} else {
closedAt = df.asString('yyyy/MM/dd hh:mm:ss', new Date(issue.closed_at))
}
table += ` ${closedAt} |\n`
}
fs.copyFileSync(path.join(__dirname, 'template.md'), path.join(__dirname, year, month, 'post.md'))
fs.writeFileSync(path.join(__dirname, year, month, 'table.md'), table, {encoding: 'UTF-8'})
}