Commit 3271c5f0 authored by Mike Greiling's avatar Mike Greiling

Prettify vue_shared modules

parent 8b7c86ea
...@@ -118,7 +118,9 @@ export default { ...@@ -118,7 +118,9 @@ export default {
this.rectYAxisLabelDims.height != null ? this.rectYAxisLabelDims.height / 2 : 0; this.rectYAxisLabelDims.height != null ? this.rectYAxisLabelDims.height / 2 : 0;
const yCoord = this.vbHeight / 2 + rectWidth - 5; const yCoord = this.vbHeight / 2 + rectWidth - 5;
return `translate(${this.minX + this.yAxisTextTransformPadding}, ${yCoord}) rotate(-${this.yAxisTextRotation})`; return `translate(${this.minX + this.yAxisTextTransformPadding}, ${yCoord}) rotate(-${
this.yAxisTextRotation
})`;
}, },
}, },
mounted() { mounted() {
...@@ -207,8 +209,7 @@ export default { ...@@ -207,8 +209,7 @@ export default {
renderedYAxis.selectAll('.tick').each(function createTickLines(d, i) { renderedYAxis.selectAll('.tick').each(function createTickLines(d, i) {
if (i > 0) { if (i > 0) {
d3 d3.select(this)
.select(this)
.select('line') .select('line')
.attr('x2', width) .attr('x2', width)
.attr('class', 'axis-tick'); .attr('class', 'axis-tick');
...@@ -217,8 +218,7 @@ export default { ...@@ -217,8 +218,7 @@ export default {
// Add the panning capabilities // Add the panning capabilities
if (this.isPanAvailable) { if (this.isPanAvailable) {
d3 d3.select(this.$refs.baseSvg)
.select(this.$refs.baseSvg)
.call(this.zoom) .call(this.zoom)
.on('wheel.zoom', null); // This disables the pan of the graph with the scroll of the mouse wheel .on('wheel.zoom', null); // This disables the pan of the graph with the scroll of the mouse wheel
} }
......
<script> <script>
/* eslint-disable vue/require-default-prop */ /* eslint-disable vue/require-default-prop */
export default { export default {
name: 'DeprecatedModal', // use GlModal instead name: 'DeprecatedModal', // use GlModal instead
props: { props: {
...@@ -79,7 +79,7 @@ ...@@ -79,7 +79,7 @@
this.$emit('submit', event); this.$emit('submit', event);
}, },
}, },
}; };
</script> </script>
<template> <template>
......
...@@ -583,7 +583,5 @@ const fileNameIcons = { ...@@ -583,7 +583,5 @@ const fileNameIcons = {
}; };
export default function getIconForFile(name) { export default function getIconForFile(name) {
return fileNameIcons[name] || return fileNameIcons[name] || fileExtensionIcons[name ? name.split('.').pop() : ''] || '';
fileExtensionIcons[name ? name.split('.').pop() : ''] ||
'';
} }
...@@ -41,10 +41,14 @@ export default { ...@@ -41,10 +41,14 @@ export default {
}, },
}, },
mounted() { mounted() {
$(this.$el).on('shown.bs.modal', this.opened).on('hidden.bs.modal', this.closed); $(this.$el)
.on('shown.bs.modal', this.opened)
.on('hidden.bs.modal', this.closed);
}, },
beforeDestroy() { beforeDestroy() {
$(this.$el).off('shown.bs.modal', this.opened).off('hidden.bs.modal', this.closed); $(this.$el)
.off('shown.bs.modal', this.opened)
.off('hidden.bs.modal', this.closed);
}, },
methods: { methods: {
emitCancel(event) { emitCancel(event) {
......
<script> <script>
// only allow classes in images.scss e.g. s12 // only allow classes in images.scss e.g. s12
const validSizes = [8, 10, 12, 16, 18, 24, 32, 48, 72]; const validSizes = [8, 10, 12, 16, 18, 24, 32, 48, 72];
let iconValidator = () => true; let iconValidator = () => true;
......
<script> <script>
import icon from '../../../vue_shared/components/icon.vue'; import icon from '../../../vue_shared/components/icon.vue';
export default { export default {
components: { components: {
icon, icon,
}, },
...@@ -28,7 +28,7 @@ ...@@ -28,7 +28,7 @@
return this.isConfidential && this.isLocked; return this.isConfidential && this.isLocked;
}, },
}, },
}; };
</script> </script>
<template> <template>
<div class="issuable-note-warning"> <div class="issuable-note-warning">
......
<script> <script>
/* eslint-disable vue/require-default-prop */ /* eslint-disable vue/require-default-prop */
/* This is a re-usable vue component for rendering a button /* This is a re-usable vue component for rendering a button
that will probably be sending off ajax requests and need that will probably be sending off ajax requests and need
to show the loading status by setting the `loading` option. to show the loading status by setting the `loading` option.
This can also be used for initial page load when you don't This can also be used for initial page load when you don't
...@@ -17,7 +17,7 @@ ...@@ -17,7 +17,7 @@
*/ */
export default { export default {
props: { props: {
loading: { loading: {
type: Boolean, type: Boolean,
...@@ -44,7 +44,7 @@ ...@@ -44,7 +44,7 @@
this.$emit('click', e); this.$emit('click', e);
}, },
}, },
}; };
</script> </script>
<template> <template>
......
<script> <script>
import $ from 'jquery'; import $ from 'jquery';
import { s__ } from '~/locale'; import { s__ } from '~/locale';
import Flash from '../../../flash'; import Flash from '../../../flash';
import GLForm from '../../../gl_form'; import GLForm from '../../../gl_form';
import markdownHeader from './header.vue'; import markdownHeader from './header.vue';
import markdownToolbar from './toolbar.vue'; import markdownToolbar from './toolbar.vue';
import icon from '../icon.vue'; import icon from '../icon.vue';
export default { export default {
components: { components: {
markdownHeader, markdownHeader,
markdownToolbar, markdownToolbar,
...@@ -135,7 +135,7 @@ ...@@ -135,7 +135,7 @@
}markdown_version=${markdownVersion}`; }markdown_version=${markdownVersion}`;
}, },
}, },
}; };
</script> </script>
<template> <template>
......
<script> <script>
import $ from 'jquery'; import $ from 'jquery';
import tooltip from '../../directives/tooltip'; import tooltip from '../../directives/tooltip';
import toolbarButton from './toolbar_button.vue'; import toolbarButton from './toolbar_button.vue';
import icon from '../icon.vue'; import icon from '../icon.vue';
export default { export default {
directives: { directives: {
tooltip, tooltip,
}, },
...@@ -38,9 +38,10 @@ ...@@ -38,9 +38,10 @@
}, },
methods: { methods: {
isValid(form) { isValid(form) {
return !form || return (
form.find('.js-vue-markdown-field').length && !form ||
$(this.$el).closest('form')[0] === form[0]; (form.find('.js-vue-markdown-field').length && $(this.$el).closest('form')[0] === form[0])
);
}, },
previewMarkdownTab(event, form) { previewMarkdownTab(event, form) {
...@@ -57,7 +58,7 @@ ...@@ -57,7 +58,7 @@
this.$emit('write-markdown'); this.$emit('write-markdown');
}, },
}, },
}; };
</script> </script>
<template> <template>
......
<script> <script>
import { Link } from '@gitlab-org/gitlab-ui'; import { Link } from '@gitlab-org/gitlab-ui';
export default { export default {
components: { components: {
'gl-link': Link, 'gl-link': Link,
}, },
...@@ -26,7 +26,7 @@ ...@@ -26,7 +26,7 @@
return this.quickActionsDocsPath !== ''; return this.quickActionsDocsPath !== '';
}, },
}, },
}; };
</script> </script>
<template> <template>
......
<script> <script>
import tooltip from '../../directives/tooltip'; import tooltip from '../../directives/tooltip';
import icon from '../icon.vue'; import icon from '../icon.vue';
export default { export default {
components: { components: {
icon, icon,
}, },
...@@ -38,7 +38,7 @@ ...@@ -38,7 +38,7 @@
default: false, default: false,
}, },
}, },
}; };
</script> </script>
<template> <template>
......
...@@ -41,7 +41,8 @@ export default { ...@@ -41,7 +41,8 @@ export default {
// Find metric timestamp which is closest to deploymentTime // Find metric timestamp which is closest to deploymentTime
timestampDiff = Math.abs(metricTimestamps[0] - median); timestampDiff = Math.abs(metricTimestamps[0] - median);
metricTimestamps.forEach((timestamp, index) => { metricTimestamps.forEach((timestamp, index) => {
if (index === 0) { // Skip first element if (index === 0) {
// Skip first element
return; return;
} }
......
<script> <script>
/** /**
* Common component to render a placeholder note and user information. * Common component to render a placeholder note and user information.
* *
* This component needs to be used with a vuex store. * This component needs to be used with a vuex store.
...@@ -16,10 +16,10 @@ ...@@ -16,10 +16,10 @@
* :note="{body: 'This is a note'}" * :note="{body: 'This is a note'}"
* /> * />
*/ */
import { mapGetters } from 'vuex'; import { mapGetters } from 'vuex';
import userAvatarLink from '../user_avatar/user_avatar_link.vue'; import userAvatarLink from '../user_avatar/user_avatar_link.vue';
export default { export default {
name: 'PlaceholderNote', name: 'PlaceholderNote',
components: { components: {
userAvatarLink, userAvatarLink,
...@@ -31,11 +31,9 @@ ...@@ -31,11 +31,9 @@
}, },
}, },
computed: { computed: {
...mapGetters([ ...mapGetters(['getUserData']),
'getUserData',
]),
}, },
}; };
</script> </script>
<template> <template>
......
<script> <script>
/** /**
* Common component to render a placeholder system note. * Common component to render a placeholder system note.
* *
* @example * @example
...@@ -7,7 +7,7 @@ ...@@ -7,7 +7,7 @@
* :note="{ body: 'Commands are being applied'}" * :note="{ body: 'Commands are being applied'}"
* /> * />
*/ */
export default { export default {
name: 'PlaceholderSystemNote', name: 'PlaceholderSystemNote',
props: { props: {
note: { note: {
...@@ -15,7 +15,7 @@ ...@@ -15,7 +15,7 @@
required: true, required: true,
}, },
}, },
}; };
</script> </script>
<template> <template>
......
<script> <script>
export default { export default {
props: { props: {
startSize: { startSize: {
type: Number, type: Number,
...@@ -84,7 +84,7 @@ ...@@ -84,7 +84,7 @@
this.$emit('resize-end', this.size); this.$emit('resize-end', this.size);
}, },
}, },
}; };
</script> </script>
<template> <template>
......
<script> <script>
import Pikaday from 'pikaday'; import Pikaday from 'pikaday';
import { parsePikadayDate, pikadayToString } from '../../lib/utils/datefix'; import { parsePikadayDate, pikadayToString } from '../../lib/utils/datefix';
export default { export default {
name: 'DatePicker', name: 'DatePicker',
props: { props: {
label: { label: {
...@@ -56,7 +56,7 @@ ...@@ -56,7 +56,7 @@
this.$emit('hidePicker'); this.$emit('hidePicker');
}, },
}, },
}; };
</script> </script>
<template> <template>
......
<script> <script>
/* This is a re-usable vue component for rendering a project avatar that
/* This is a re-usable vue component for rendering a project avatar that
does not need to link to the project's profile. The image and an optional does not need to link to the project's profile. The image and an optional
tooltip can be configured by props passed to this component. tooltip can be configured by props passed to this component.
...@@ -16,11 +15,11 @@ ...@@ -16,11 +15,11 @@
*/ */
import defaultAvatarUrl from 'images/no_avatar.png'; import defaultAvatarUrl from 'images/no_avatar.png';
import { placeholderImage } from '../../../lazy_loader'; import { placeholderImage } from '../../../lazy_loader';
import tooltip from '../../directives/tooltip'; import tooltip from '../../directives/tooltip';
export default { export default {
name: 'ProjectAvatarImage', name: 'ProjectAvatarImage',
directives: { directives: {
tooltip, tooltip,
...@@ -79,7 +78,7 @@ ...@@ -79,7 +78,7 @@
return `s${this.size}`; return `s${this.size}`;
}, },
}, },
}; };
</script> </script>
<template> <template>
......
<script> <script>
import DeprecatedModal from './deprecated_modal.vue'; import DeprecatedModal from './deprecated_modal.vue';
export default { export default {
name: 'RecaptchaModal', name: 'RecaptchaModal',
components: { components: {
...@@ -61,7 +61,7 @@ ...@@ -61,7 +61,7 @@
this.$el.querySelector('form').submit(); this.$el.querySelector('form').submit();
}, },
}, },
}; };
</script> </script>
<template> <template>
......
<script> <script>
import datePicker from '../pikaday.vue'; import datePicker from '../pikaday.vue';
import toggleSidebar from './toggle_sidebar.vue'; import toggleSidebar from './toggle_sidebar.vue';
import collapsedCalendarIcon from './collapsed_calendar_icon.vue'; import collapsedCalendarIcon from './collapsed_calendar_icon.vue';
import { dateInWords } from '../../../lib/utils/datetime_utility'; import { dateInWords } from '../../../lib/utils/datetime_utility';
export default { export default {
name: 'SidebarDatePicker', name: 'SidebarDatePicker',
components: { components: {
datePicker, datePicker,
...@@ -90,7 +90,7 @@ ...@@ -90,7 +90,7 @@
this.$emit('toggleCollapse'); this.$emit('toggleCollapse');
}, },
}, },
}; };
</script> </script>
<template> <template>
......
<script> <script>
import { s__ } from '../../locale'; import { s__ } from '../../locale';
const PAGINATION_UI_BUTTON_LIMIT = 4; const PAGINATION_UI_BUTTON_LIMIT = 4;
const UI_LIMIT = 6; const UI_LIMIT = 6;
const SPREAD = '...'; const SPREAD = '...';
const PREV = s__('Pagination|Prev'); const PREV = s__('Pagination|Prev');
const NEXT = s__('Pagination|Next'); const NEXT = s__('Pagination|Next');
const FIRST = s__('Pagination|« First'); const FIRST = s__('Pagination|« First');
const LAST = s__('Pagination|Last »'); const LAST = s__('Pagination|Last »');
export default { export default {
props: { props: {
/** /**
This function will take the information given by the pagination component This function will take the information given by the pagination component
...@@ -128,7 +128,7 @@ ...@@ -128,7 +128,7 @@
return !item.first && !item.last && !item.next && !item.prev && !item.active; return !item.first && !item.last && !item.next && !item.prev && !item.active;
}, },
}, },
}; };
</script> </script>
<template> <template>
<div <div
......
...@@ -11,9 +11,7 @@ export default { ...@@ -11,9 +11,7 @@ export default {
directives: { directives: {
tooltip, tooltip,
}, },
mixins: [ mixins: [timeagoMixin],
timeagoMixin,
],
props: { props: {
time: { time: {
type: String, type: String,
......
<script> <script>
import { s__ } from '../../locale'; import { s__ } from '../../locale';
import icon from './icon.vue'; import icon from './icon.vue';
const ICON_ON = 'status_success_borderless'; const ICON_ON = 'status_success_borderless';
const ICON_OFF = 'status_failed_borderless'; const ICON_OFF = 'status_failed_borderless';
const LABEL_ON = s__('ToggleButton|Toggle Status: ON'); const LABEL_ON = s__('ToggleButton|Toggle Status: ON');
const LABEL_OFF = s__('ToggleButton|Toggle Status: OFF'); const LABEL_OFF = s__('ToggleButton|Toggle Status: OFF');
export default { export default {
components: { components: {
icon, icon,
}, },
...@@ -54,7 +54,7 @@ ...@@ -54,7 +54,7 @@
if (!this.disabledInput) this.$emit('change', !this.value); if (!this.disabledInput) this.$emit('change', !this.value);
}, },
}, },
}; };
</script> </script>
<template> <template>
......
<script> <script>
/* This is a re-usable vue component for rendering a user avatar wrapped in /* This is a re-usable vue component for rendering a user avatar wrapped in
a clickable link (likely to the user's profile). The link, image, and a clickable link (likely to the user's profile). The link, image, and
tooltip can be configured by props passed to this component. tooltip can be configured by props passed to this component.
......
<script> <script>
/* This is a re-usable vue component for rendering a user avatar svg (typically /* This is a re-usable vue component for rendering a user avatar svg (typically
for a blank state). It will receive styles comparable to the user avatar, for a blank state). It will receive styles comparable to the user avatar,
but no image is loaded, it isn't wrapped in a link, and tooltips aren't supported. but no image is loaded, it isn't wrapped in a link, and tooltips aren't supported.
...@@ -42,4 +41,3 @@ export default { ...@@ -42,4 +41,3 @@ export default {
v-html="svg" v-html="svg"
/> />
</template> </template>
...@@ -4,10 +4,7 @@ ...@@ -4,10 +4,7 @@
* *
* Components need to have `scope`, `page` and `requestData` * Components need to have `scope`, `page` and `requestData`
*/ */
import { import { historyPushState, buildUrlWithCurrentLocation } from '../../lib/utils/common_utils';
historyPushState,
buildUrlWithCurrentLocation,
} from '../../lib/utils/common_utils';
export default { export default {
methods: { methods: {
...@@ -24,12 +21,14 @@ export default { ...@@ -24,12 +21,14 @@ export default {
// stop polling // stop polling
this.poll.stop(); this.poll.stop();
const queryString = Object.keys(parameters).map((parameter) => { const queryString = Object.keys(parameters)
.map(parameter => {
const value = parameters[parameter]; const value = parameters[parameter];
// update internal state for UI // update internal state for UI
this[parameter] = value; this[parameter] = value;
return `${parameter}=${encodeURIComponent(value)}`; return `${parameter}=${encodeURIComponent(value)}`;
}).join('&'); })
.join('&');
// update polling parameters // update polling parameters
this.requestData = parameters; this.requestData = parameters;
......
...@@ -6,7 +6,7 @@ export default class ListLabel { ...@@ -6,7 +6,7 @@ export default class ListLabel {
this.color = obj.color; this.color = obj.color;
this.textColor = obj.text_color; this.textColor = obj.text_color;
this.description = obj.description; this.description = obj.description;
this.priority = (obj.priority !== null) ? obj.priority : Infinity; this.priority = obj.priority !== null ? obj.priority : Infinity;
} }
} }
......
import { import { __, n__, s__, sprintf } from '../locale';
__,
n__,
s__,
sprintf,
} from '../locale';
export default (Vue) => { export default Vue => {
Vue.mixin({ Vue.mixin({
methods: { methods: {
/** /**
......
...@@ -21,7 +21,7 @@ Vue.http.interceptors.push((request, next) => { ...@@ -21,7 +21,7 @@ Vue.http.interceptors.push((request, next) => {
Vue.http.interceptors.push((request, next) => { Vue.http.interceptors.push((request, next) => {
request.headers.set(csrf.headerKey, csrf.token); request.headers.set(csrf.headerKey, csrf.token);
next((response) => { next(response => {
// Headers object has a `forEach` property that iterates through all values. // Headers object has a `forEach` property that iterates through all values.
const headers = {}; const headers = {};
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment