mirror of
https://github.com/status-im/figma-diff-probot.git
synced 2025-02-22 17:18:27 +00:00
Updating probot script to watch for primer component changes also
This commit is contained in:
parent
6b7cdd2398
commit
bc78310616
126
index.js
126
index.js
@ -29,7 +29,7 @@ const getFigmaComponents = (figmaFileKey) => {
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
const getFigmaImages = (figmaFileKey, componentIds) => {
|
const getFigmaImages = (figmaFileKey, componentIds, aws=true) => {
|
||||||
return new Promise((resolve, reject) => {
|
return new Promise((resolve, reject) => {
|
||||||
got.get(`https://api.figma.com/v1/images/${figmaFileKey}`, {
|
got.get(`https://api.figma.com/v1/images/${figmaFileKey}`, {
|
||||||
query: {
|
query: {
|
||||||
@ -47,6 +47,7 @@ const getFigmaImages = (figmaFileKey, componentIds) => {
|
|||||||
}
|
}
|
||||||
})
|
})
|
||||||
.then(images => {
|
.then(images => {
|
||||||
|
if (aws) {
|
||||||
resolve(
|
resolve(
|
||||||
Promise.all(Object.keys(images).map(k => {
|
Promise.all(Object.keys(images).map(k => {
|
||||||
const url = images[k]
|
const url = images[k]
|
||||||
@ -61,6 +62,9 @@ const getFigmaImages = (figmaFileKey, componentIds) => {
|
|||||||
})
|
})
|
||||||
}))
|
}))
|
||||||
)
|
)
|
||||||
|
} else {
|
||||||
|
resolve(images)
|
||||||
|
}
|
||||||
})
|
})
|
||||||
.catch(err => reject(err))
|
.catch(err => reject(err))
|
||||||
})
|
})
|
||||||
@ -76,30 +80,17 @@ const hasChanged = (before, after) => {
|
|||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
// Template
|
const getFigmaFileId = (str) => {
|
||||||
const changeComment = (data) => {
|
return /www\.figma\.com\/file\/(.+)\//.exec(str).pop()
|
||||||
return `
|
|
||||||
| Before | After |
|
|
||||||
| :-- | :-- |
|
|
||||||
${Object.values(data.before.components).map((b) => {
|
|
||||||
const a = data.after.components[b.id]
|
|
||||||
return `| **Name:** \`${b.name}\`<br>**Description:** \`${b.description}\` [<img src="${b.image.url}" height="200"/>](${b.image.url}) | **Name:** \`${a.name}\`<br>**Description:** \`${a.description}\` [<img src="${a.image.url}" height="200"/>](${a.image.url}) |`
|
|
||||||
}).join('\n')}`
|
|
||||||
}
|
}
|
||||||
|
|
||||||
module.exports = robot => {
|
const octiconsBeforeAfter = async (diff, context) => {
|
||||||
// Will trigger whenever a new PR is opened or pushed to
|
|
||||||
robot.on(['pull_request.opened', 'pull_request.synchronize'], async context => {
|
|
||||||
// Get the diff of the PR
|
|
||||||
const diff = (await context.github.pullRequests.get(context.issue({
|
|
||||||
headers: { Accept: 'application/vnd.github.diff' }
|
|
||||||
}))).data
|
|
||||||
|
|
||||||
let data = {}
|
let data = {}
|
||||||
|
|
||||||
diff.match(/^[-+]\s.*www\.figma\.com\/file\/.+\//gm).forEach(m => {
|
diff.match(/^[-+]\s.*www\.figma\.com\/file\/.+\//gm).forEach(m => {
|
||||||
data[m[0] === '-' ? 'before' : 'after'] = {
|
data[m[0] === '-' ? 'before' : 'after'] = {
|
||||||
'fileId': /www\.figma\.com\/file\/(.+)\//.exec(m).pop()
|
'fileId': getFigmaFileId(m)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
@ -136,9 +127,104 @@ module.exports = robot => {
|
|||||||
if (Object.keys(data.before.components).length === 0 ||
|
if (Object.keys(data.before.components).length === 0 ||
|
||||||
Object.keys(data.after.components).length === 0) return
|
Object.keys(data.after.components).length === 0) return
|
||||||
|
|
||||||
const params = context.issue({body: changeComment(data)})
|
return `
|
||||||
|
| Before | After |
|
||||||
|
| :-- | :-- |
|
||||||
|
${Object.values(data.before.components).map((b) => {
|
||||||
|
const a = data.after.components[b.id]
|
||||||
|
return `| **Name:** \`${b.name}\`<br>**Description:** \`${b.description}\` [<img src="${b.image.url}" height="200"/>](${b.image.url}) | **Name:** \`${a.name}\`<br>**Description:** \`${a.description}\` [<img src="${a.image.url}" height="200"/>](${a.image.url}) |`
|
||||||
|
}).join('\n')}`
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return context.github.issues.createComment(params)
|
const primerComponentChanges = async (diff, context) => {
|
||||||
|
|
||||||
|
let modules = diff.match(/^diff --git a\/([\w\/\-]*).scss/gm).map(line => {
|
||||||
|
|
||||||
|
const file = /^diff --git a\/([\w\/\-]*).scss/.exec(line).pop().split("/")
|
||||||
|
return {
|
||||||
|
name: file[1],
|
||||||
|
path: `${file.slice(0,2).join("/")}/package.json`,
|
||||||
|
components: []
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
// If a scss file was changed
|
||||||
|
modules = (await modules.map(async m => {
|
||||||
|
|
||||||
|
// Getting module package.json from github and parsing as JSON
|
||||||
|
const pkg = JSON.parse(Buffer.from((await context.github.repos.getContent(context.repo({
|
||||||
|
path: m.path,
|
||||||
|
ref: context.payload.pull_request.head.ref,
|
||||||
|
repo: context.payload.repository.name,
|
||||||
|
owner: context.payload.repository.owner.login
|
||||||
|
}))).data.content, 'base64').toString())
|
||||||
|
|
||||||
|
m.url = pkg.figma.url
|
||||||
|
|
||||||
|
const components = Object.values(pkg.figma.components).map(m => m.id).join(",")
|
||||||
|
const fileId = getFigmaFileId(pkg.figma.url)
|
||||||
|
|
||||||
|
let images = (await getFigmaImages(fileId, components, false))
|
||||||
|
Object.keys(images).map(i => {
|
||||||
|
m.components.push({
|
||||||
|
id: i,
|
||||||
|
url: images[i],
|
||||||
|
name: Object.keys(pkg.figma.components).find(k => pkg.figma.components[k].id == i)
|
||||||
|
})
|
||||||
|
})
|
||||||
|
m.components.sort((a, b) => b.name - a.name)
|
||||||
|
return m
|
||||||
|
}))
|
||||||
|
return Promise.all(modules)
|
||||||
|
.then(modules => {
|
||||||
|
const componentsTemplate = (module) => {
|
||||||
|
return module.components.map(i => {
|
||||||
|
return `* \`${i.name}\` – 🔗[figma file](${module.url}?node-id=${encodeURIComponent(i.id)})
|
||||||
|
|
||||||
|
[data:image/s3,"s3://crabby-images/cd825/cd8254e8fdbffb1a2bf287e5490f7d04690ebf1b" alt=""](${module.url}?node-id=${encodeURIComponent(i.id)})`
|
||||||
|
}).join("\n")
|
||||||
|
}
|
||||||
|
|
||||||
|
return `@${context.payload.pull_request.user.login} This pull request changes the \`${modules.map(m => m.name).join(", ")}\` module${(modules.length > 1 ? 's' : '')}. Here are a list of what the components currently look like in figma.
|
||||||
|
|
||||||
|
${modules.map(module => {
|
||||||
|
return `#### ${module.name}\n${componentsTemplate(module)}`
|
||||||
|
}).join("\n")}`
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = robot => {
|
||||||
|
|
||||||
|
// Will trigger whenever a new PR is opened or pushed to
|
||||||
|
robot.on(['pull_request.opened', 'pull_request.synchronize'], async context => {
|
||||||
|
let message = ""
|
||||||
|
// Get the diff of the PR
|
||||||
|
const diff = (await context.github.pullRequests.get(context.issue({
|
||||||
|
headers: { Accept: 'application/vnd.github.diff' }
|
||||||
|
}))).data
|
||||||
|
|
||||||
|
switch (context.payload.repository.full_name) {
|
||||||
|
case "primer/octicons":
|
||||||
|
message = (await octiconsBeforeAfter(diff, context))
|
||||||
|
break;
|
||||||
|
case "primer/primer":
|
||||||
|
message = (await primerComponentChanges(diff, context))
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
}
|
||||||
|
|
||||||
|
// Determine if there is already a comment on this PR from ci-reporter
|
||||||
|
const comments = await context.github.issues.getComments(context.issue({ number: context.payload.pull_request.number }))
|
||||||
|
const comment = comments.data.find(comment => comment.user.login === 'figma-diff[bot]')
|
||||||
|
|
||||||
|
// If there is, edit that one
|
||||||
|
if (comment) {
|
||||||
|
const params = context.issue({id: comment.id, body: message})
|
||||||
|
return context.github.issues.editComment(params)
|
||||||
|
} else {
|
||||||
|
const params = context.issue({body: message})
|
||||||
|
return context.github.issues.createComment(params)
|
||||||
|
}
|
||||||
|
|
||||||
|
})
|
||||||
}
|
}
|
||||||
|
@ -11,7 +11,7 @@
|
|||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"got": "^8.3.0",
|
"got": "^8.3.0",
|
||||||
"probot": "^6.0.0"
|
"probot": "^6.1.0"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"jest": "^21.2.1",
|
"jest": "^21.2.1",
|
||||||
|
Loading…
x
Reference in New Issue
Block a user