/*= require vue */ /* global Vue */ (() => { window.gl = window.gl || {}; window.gl.CommitComponent = Vue.component('commit-component', { props: { /** * Indicates the existance of a tag. * Used to render the correct icon, if true will render `fa-tag` icon, * if false will render `fa-code-fork` icon. */ tag: { type: Boolean, required: false, default: false, }, /** * If provided is used to render the branch name and url. * Should contain the following properties: * name * ref_url */ commitRef: { type: Object, required: false, default: () => ({}), }, /** * Used to link to the commit sha. */ commitUrl: { type: String, required: false, default: '', }, /** * Used to show the commit short sha that links to the commit url. */ shortSha: { type: String, required: false, default: '', }, /** * If provided shows the commit tile. */ title: { type: String, required: false, default: '', }, /** * If provided renders information about the author of the commit. * When provided should include: * `avatar_url` to render the avatar icon * `web_url` to link to user profile * `username` to render alt and title tags */ author: { type: Object, required: false, default: () => ({}), }, commitIconSvg: { type: String, required: false, }, }, computed: { /** * Used to verify if all the properties needed to render the commit * ref section were provided. * * TODO: Improve this! Use lodash _.has when we have it. * * @returns {Boolean} */ hasCommitRef() { return this.commitRef && this.commitRef.name && this.commitRef.ref_url; }, /** * Used to verify if all the properties needed to render the commit * author section were provided. * * TODO: Improve this! Use lodash _.has when we have it. * * @returns {Boolean} */ hasAuthor() { return this.author && this.author.avatar_url && this.author.web_url && this.author.username; }, /** * If information about the author is provided will return a string * to be rendered as the alt attribute of the img tag. * * @returns {String} */ userImageAltDescription() { return this.author && this.author.username ? `${this.author.username}'s avatar` : null; }, }, template: `
`, }); })();