Bauke/tildes-issue-log
Bauke
/
tildes-issue-log
Archived
1
Fork 0
This repository has been archived on 2022-10-04. You can view files and clone it, but cannot push or open issues or pull requests.
tildes-issue-log/main.js

149 lines
4.1 KiB
JavaScript
Raw Normal View History

2018-06-24 16:38:50 +00:00
const config = require('./config.json')
2018-06-24 17:55:47 +00:00
const df = require('date-format')
2018-06-24 16:38:50 +00:00
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()
2018-06-24 17:55:47 +00:00
else createTable()
2018-06-24 16:38:50 +00:00
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))
}
}
})
2018-06-24 17:55:47 +00:00
.then(createTable)
2018-06-24 16:38:50 +00:00
})
}
2018-06-24 17:55:47 +00:00
function createTable() {
2018-06-24 16:38:50 +00:00
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)
})
2018-06-24 17:55:47 +00:00
let table = '## Issue Table\n'
table += '\n### Opened\n\n'
table += '| Issue | Title | Author | Opened | Closed |\n'
table += '| ----- | ----- | ------ | ------ | ------ |\n'
2018-06-24 16:38:50 +00:00
for (const file of opened) {
const issue = require(file.path)
2018-06-24 17:55:47 +00:00
table += `| <a href="${issue.web_url}" target="_blank">${issue.iid}</a> |`
2018-06-24 16:38:50 +00:00
let title
if (issue.title.length >= 50) {
title = issue.title.substring(0, 47) + '...'
} else {
title = issue.title
}
2018-06-24 17:55:47 +00:00
table += ` ${title} |`
table += ` <a href="${issue.author.web_url}">${issue.author.username}</a> |`
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`
2018-06-24 16:38:50 +00:00
}
2018-06-24 17:55:47 +00:00
table += '\n### Closed\n\n'
table += '| Issue | Title | Author | Opened | Closed |\n'
table += '| ----- | ----- | ------ | ------ | ------ |\n'
2018-06-24 16:38:50 +00:00
for (const file of closed) {
const issue = require(file.path)
2018-06-24 17:55:47 +00:00
table += `| <a href="${issue.web_url}" target="_blank">${issue.iid}</a> |`
2018-06-24 16:38:50 +00:00
let title
if (issue.title.length >= 50) {
title = issue.title.substring(0, 47) + '...'
} else {
title = issue.title
}
2018-06-24 17:55:47 +00:00
table += ` ${title} |`
table += ` <a href="${issue.author.web_url}">${issue.author.username}</a> |`
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`
2018-06-24 16:38:50 +00:00
}
fs.copyFileSync(path.join(__dirname, 'template.md'), path.join(__dirname, year, month, 'post.md'))
2018-06-24 17:55:47 +00:00
fs.writeFileSync(path.join(__dirname, year, month, 'table.md'), table, {encoding: 'UTF-8'})
2018-06-24 16:38:50 +00:00
}