2018-12-09 13:21:20 +00:00
|
|
|
<template>
|
|
|
|
<div>
|
|
|
|
<projbreadcrumbs :ownertype="ownertype" :ownername="ownername" :projectname="projectname"/>
|
|
|
|
<div class="tabs">
|
|
|
|
<ul>
|
|
|
|
<li
|
2019-03-27 14:41:29 +00:00
|
|
|
:class="[{ 'is-active': $route.name.match('project runs') || $route.name.endsWith('project') }]"
|
2018-12-09 13:21:20 +00:00
|
|
|
>
|
2019-03-27 14:41:29 +00:00
|
|
|
<router-link :to="projectRunsLink(ownertype, ownername, projectname)">Runs History</router-link>
|
|
|
|
</li>
|
|
|
|
<li :class="[{ 'is-active': $route.name.match('project branches runs') }]">
|
|
|
|
<router-link :to="projectBranchesRunsLink(ownertype, ownername, projectname)">Branches</router-link>
|
|
|
|
</li>
|
|
|
|
<li :class="[{ 'is-active': $route.name.match('project tags runs') }]">
|
|
|
|
<router-link :to="projectTagsRunsLink(ownertype, ownername, projectname)">Tags</router-link>
|
|
|
|
</li>
|
|
|
|
<li :class="[{ 'is-active': $route.name.match('project pull requests runs') }]">
|
|
|
|
<router-link :to="projectPRsRunsLink(ownertype, ownername, projectname)">Pull Requests</router-link>
|
2018-12-09 13:21:20 +00:00
|
|
|
</li>
|
|
|
|
<li
|
|
|
|
v-if="$route.name.endsWith('project run') || $route.name.endsWith('project run task')"
|
|
|
|
:class="[{ 'is-active': $route.name.endsWith('project run') }]"
|
|
|
|
>
|
|
|
|
<tabarrow/>
|
|
|
|
</li>
|
|
|
|
<li
|
|
|
|
v-if="$route.name.endsWith('project run') || $route.name.endsWith('project run task')"
|
|
|
|
:class="[{ 'is-active': $route.name.endsWith('project run') }]"
|
|
|
|
>
|
|
|
|
<router-link
|
|
|
|
:to="projectRunLink(ownertype, ownername, $route.params.projectname, $route.params.runid)"
|
2019-03-27 14:41:29 +00:00
|
|
|
>
|
|
|
|
<p v-if="run">
|
|
|
|
Run
|
|
|
|
<strong>#{{run.counter}}</strong>
|
|
|
|
</p>
|
|
|
|
</router-link>
|
2018-12-09 13:21:20 +00:00
|
|
|
</li>
|
|
|
|
<li
|
|
|
|
v-if="$route.name.endsWith('project run task')"
|
|
|
|
:class="[{ 'is-active': $route.name.endsWith('project run') }]"
|
|
|
|
>
|
|
|
|
<tabarrow/>
|
|
|
|
</li>
|
|
|
|
<li v-if="$route.name.endsWith('project run task')" class="is-active">
|
|
|
|
<router-link
|
|
|
|
:to="projectRunTaskLink(ownertype, ownername, $route.params.projectname, $route.params.runid, $route.params.taskid)"
|
2019-03-27 14:41:29 +00:00
|
|
|
>
|
|
|
|
<p v-if="run">
|
|
|
|
Task
|
|
|
|
<strong>{{run.tasks[$route.params.taskid].name}}</strong>
|
|
|
|
</p>
|
|
|
|
</router-link>
|
2018-12-09 13:21:20 +00:00
|
|
|
</li>
|
|
|
|
</ul>
|
2019-03-22 07:39:03 +00:00
|
|
|
<ul class="is-right">
|
|
|
|
<li :class="[{ 'is-active': $route.name.endsWith('project settings') }]">
|
|
|
|
<router-link :to="projectSettingsLink(ownertype, ownername, projectname)">Project Settings</router-link>
|
|
|
|
</li>
|
|
|
|
</ul>
|
2018-12-09 13:21:20 +00:00
|
|
|
</div>
|
|
|
|
<router-view></router-view>
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
|
|
<script>
|
|
|
|
import {
|
|
|
|
projectLink,
|
|
|
|
projectRunsLink,
|
2019-03-27 14:41:29 +00:00
|
|
|
projectBranchesRunsLink,
|
|
|
|
projectTagsRunsLink,
|
|
|
|
projectPRsRunsLink,
|
2018-12-09 13:21:20 +00:00
|
|
|
projectRunLink,
|
2019-03-22 07:39:03 +00:00
|
|
|
projectRunTaskLink,
|
|
|
|
projectSettingsLink
|
2018-12-09 13:21:20 +00:00
|
|
|
} from "@/util/link.js";
|
|
|
|
|
2019-03-27 14:41:29 +00:00
|
|
|
import { fetchRun } from "@/util/data.js";
|
|
|
|
|
2018-12-09 13:21:20 +00:00
|
|
|
import projbreadcrumbs from "@/components/projbreadcrumbs.vue";
|
|
|
|
import runs from "@/components/runs.vue";
|
|
|
|
import tabarrow from "@/components/tabarrow.vue";
|
|
|
|
|
|
|
|
export default {
|
|
|
|
name: "Project",
|
|
|
|
components: { projbreadcrumbs, runs, tabarrow },
|
|
|
|
props: {
|
|
|
|
ownertype: String,
|
|
|
|
ownername: String,
|
2019-03-22 07:39:03 +00:00
|
|
|
projectname: String
|
2018-12-09 13:21:20 +00:00
|
|
|
},
|
2019-03-27 14:41:29 +00:00
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
run: null
|
|
|
|
};
|
|
|
|
},
|
|
|
|
watch: {
|
|
|
|
$route: async function(route) {
|
|
|
|
if (route.params.runid) {
|
|
|
|
this.run = await fetchRun(route.params.runid);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
2018-12-09 13:21:20 +00:00
|
|
|
methods: {
|
|
|
|
projectLink: projectLink,
|
|
|
|
projectRunsLink: projectRunsLink,
|
2019-03-27 14:41:29 +00:00
|
|
|
projectBranchesRunsLink: projectBranchesRunsLink,
|
|
|
|
projectTagsRunsLink: projectTagsRunsLink,
|
|
|
|
projectPRsRunsLink: projectPRsRunsLink,
|
2018-12-09 13:21:20 +00:00
|
|
|
projectRunLink: projectRunLink,
|
2019-03-22 07:39:03 +00:00
|
|
|
projectRunTaskLink: projectRunTaskLink,
|
|
|
|
projectSettingsLink: projectSettingsLink
|
2019-03-27 14:41:29 +00:00
|
|
|
},
|
|
|
|
created: async function() {
|
|
|
|
if (this.$route.params.runid) {
|
|
|
|
this.run = await fetchRun(this.$route.params.runid);
|
|
|
|
}
|
2018-12-09 13:21:20 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<style scoped lang="scss">
|
|
|
|
@import "@/css/_variables.scss";
|
|
|
|
|
|
|
|
.user-title {
|
|
|
|
display: flex;
|
|
|
|
align-items: center;
|
|
|
|
padding-left: 5px;
|
|
|
|
margin-bottom: 25px;
|
|
|
|
.user-name {
|
|
|
|
padding-left: 5px;
|
|
|
|
font-size: 1.5rem;
|
|
|
|
padding-right: 1rem;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
</style>
|