diff options
| author | Filipa Lacerda <filipa@gitlab.com> | 2016-11-09 10:55:00 +0000 | 
|---|---|---|
| committer | Filipa Lacerda <filipa@gitlab.com> | 2016-11-16 11:58:09 +0000 | 
| commit | 3fef5e66dba055e32dda1ccc887ad630d1e61c87 (patch) | |
| tree | 1919a2aca4ae15e945e98b1875bbd32d144fb004 /app/assets/javascripts/vue_common_component/commit.js.es6 | |
| parent | a31578aa505088a347bfc6ae2483d8c563d1fee9 (diff) | |
| download | gitlab-ce-3fef5e66dba055e32dda1ccc887ad630d1e61c87.tar.gz | |
Adds template functions
Adds commit component
Diffstat (limited to 'app/assets/javascripts/vue_common_component/commit.js.es6')
| -rw-r--r-- | app/assets/javascripts/vue_common_component/commit.js.es6 | 173 | 
1 files changed, 173 insertions, 0 deletions
| diff --git a/app/assets/javascripts/vue_common_component/commit.js.es6 b/app/assets/javascripts/vue_common_component/commit.js.es6 new file mode 100644 index 00000000000..8847d1d0184 --- /dev/null +++ b/app/assets/javascripts/vue_common_component/commit.js.es6 @@ -0,0 +1,173 @@ +/*= 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 +       */ +      ref: { +        type: Object, +        required: false, +        default: () => {}, +      }, + +      /** +       * Used to link to the commit sha. +       */ +      commit_url: { +        type: String, +        required: false, +        default: '', +      }, + +      /** +       * Used to show the commit short_sha that links to the commit url. +       */ +      short_sha: { +        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: () => {}, +      }, +    }, + +    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} +       */ +      hasRef() { +        return this.ref && this.ref.name && this.ref.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; +      }, +    }, + +    /** +     * In order to reuse the svg instead of copy and paste in this template the html_safe +     * we need to render it outside this component using =custom_icon partial. +     * Make sure it has this structure: +     * .commit-icon-svg.hidden +     *   svg +     * +     * TODO: Find a better way to include SVG +     */ +    ready() { +      const commitIconContainer = document.querySelector('.branch-commit .commit-icon-container'); +      const commitIcon = document.querySelector('.commit-icon-svg.hidden svg'); + +      if (commitIconContainer && commitIcon) { +        commitIconContainer.appendChild(commitIcon); +      } +    }, + +    template: ` +      <div class="branch-commit"> + +        <div v-if="hasRef" class="icon-container"> +          <i v-if="tag" class="fa fa-tag"></i> +          <i v-else class="fa fa-code-fork"></i> +        </div> + +        <a v-if="hasRef" class="monospace branch-name" :href="ref.ref_url"> +          {{ref.name}} +        </a> + +        <div class="icon-container commit-icon commit-icon-container"> +          <!-- svg goes here --> +        </div> + +        <a class="commit-id monospace" :href="commit_url"> +          {{short_sha}} +        </a> + +        <p class="commit-title"> +          <span v-if="title"> +            <!-- commit author info--> +            <a v-if="hasAuthor" class="avatar-image-container" :href="author.web_url"> +              <img +              class="avatar has-tooltip s20" +                :src="author.avatar_url" +                :alt="userImageAltDescription" +                :title="author.username" /> +            </a> + +            <a class="commit-row-message" :href="commit_url"> +              {{title}} +            </a> +          </span> +          <span v-else> +            Cant find HEAD commit for this branch +          </span> +        </p> +      </div> +    `, +  }); +})(); | 
