fixed some state bugs with the tabs

[ci skip]
This commit is contained in:
Phil Hughes 2017-10-26 16:44:26 +01:00
parent 1543679eaf
commit bdac5569b1
No known key found for this signature in database
GPG key ID: 32245528C52E0F9F
10 changed files with 53 additions and 38 deletions

View file

@ -1,5 +1,4 @@
<script> <script>
import { mapState } from 'vuex';
import newModal from './modal.vue'; import newModal from './modal.vue';
export default { export default {
@ -12,11 +11,6 @@
modalType: '', modalType: '',
}; };
}, },
computed: {
...mapState({
currentPath: 'path',
}),
},
methods: { methods: {
createNewItem(type) { createNewItem(type) {
this.modalType = type; this.modalType = type;
@ -70,7 +64,6 @@
<new-modal <new-modal
v-if="openModal" v-if="openModal"
:type="modalType" :type="modalType"
:current-path="currentPath"
@toggle="toggleModalOpen" @toggle="toggleModalOpen"
/> />
</div> </div>

View file

@ -1,14 +1,10 @@
<script> <script>
import { mapActions } from 'vuex'; import { mapActions, mapState } from 'vuex';
import { __ } from '../../../locale'; import { __ } from '../../../locale';
import popupDialog from '../../../vue_shared/components/popup_dialog.vue'; import popupDialog from '../../../vue_shared/components/popup_dialog.vue';
export default { export default {
props: { props: {
currentPath: {
type: String,
required: true,
},
type: { type: {
type: String, type: String,
required: true, required: true,
@ -16,7 +12,7 @@
}, },
data() { data() {
return { return {
entryName: this.currentPath !== '' ? `${this.currentPath}/` : '', entryName: '',
}; };
}, },
components: { components: {
@ -39,6 +35,17 @@
}, },
}, },
computed: { computed: {
...mapState([
'path',
]),
name: {
get() {
return this.path !== '' ? `${this.path}/${this.entryName}` : this.entryName;
},
set(newVal) {
this.entryName = newVal.replace(`${this.path}/`, '');
},
},
modalTitle() { modalTitle() {
if (this.type === 'tree') { if (this.type === 'tree') {
return __('Create new directory'); return __('Create new directory');
@ -88,7 +95,7 @@
<input <input
type="text" type="text"
class="form-control" class="form-control"
v-model="entryName" v-model="name"
ref="fieldName" ref="fieldName"
/> />
</div> </div>

View file

@ -51,6 +51,8 @@ export default {
.catch(() => flash('Error setting up monaco. Please try again.')); .catch(() => flash('Error setting up monaco. Please try again.'));
}, },
setupEditor() { setupEditor() {
if (!this.activeFile) return;
const foundLang = this.languages.find(lang => const foundLang = this.languages.find(lang =>
lang.extensions && lang.extensions.indexOf(this.activeFileExtension) === 0, lang.extensions && lang.extensions.indexOf(this.activeFileExtension) === 0,
); );
@ -71,7 +73,7 @@ export default {
}, },
watch: { watch: {
activeFile(oldVal, newVal) { activeFile(oldVal, newVal) {
if (newVal.active) { if (!newVal.active) {
this.initMonaco(); this.initMonaco();
} }
}, },

View file

@ -52,13 +52,5 @@ export default {
Permalink Permalink
</a> </a>
</div> </div>
<!-- <a
v-if="canPreview"
href="#"
@click.prevent="rawPreviewToggle"
class="btn btn-default preview">
{{activeFileLabel}}
</a> -->
</div> </div>
</template> </template>

View file

@ -11,7 +11,7 @@ export default {
computed: { computed: {
closeLabel() { closeLabel() {
if (this.tab.changed) { if (this.tab.changed || this.tab.tempFile) {
return `${this.tab.name} changed`; return `${this.tab.name} changed`;
} }
return `Close ${this.tab.name}`; return `Close ${this.tab.name}`;
@ -42,7 +42,7 @@ export default {
<button <button
type="button" type="button"
class="close-btn" class="close-btn"
@click.stop.prevent="closeFile(tab)" @click.stop.prevent="closeFile({ file: tab })"
:aria-label="closeLabel"> :aria-label="closeLabel">
<i <i
class="fa" class="fa"
@ -55,7 +55,7 @@ export default {
href="#" href="#"
class="repo-tab" class="repo-tab"
:title="tab.url" :title="tab.url"
@click.prevent="setFileActive(tab)"> @click.prevent.stop="setFileActive(tab)">
{{tab.name}} {{tab.name}}
</a> </a>
</li> </li>

View file

@ -10,14 +10,22 @@ export const setInitialData = ({ commit }, data) => commit(types.SET_INITIAL_DAT
export const closeDiscardPopup = ({ commit }) => commit(types.TOGGLE_DISCARD_POPUP, false); export const closeDiscardPopup = ({ commit }) => commit(types.TOGGLE_DISCARD_POPUP, false);
export const discardAllChanges = ({ commit, getters }) => { export const discardAllChanges = ({ state, commit, getters, dispatch }) => {
if (state.editMode) return;
const changedFiles = getters.changedFiles; const changedFiles = getters.changedFiles;
changedFiles.forEach(file => commit(types.DISCARD_FILE_CHANGES, file)); changedFiles.forEach((file) => {
commit(types.DISCARD_FILE_CHANGES, file);
if (file.tempFile) {
dispatch('closeFile', { file, force: true });
}
});
}; };
export const closeAllFiles = ({ state, dispatch }) => { export const closeAllFiles = ({ state, dispatch }) => {
state.openFiles.forEach(file => dispatch('closeFile', file)); state.openFiles.forEach(file => dispatch('closeFile', { file }));
}; };
export const toggleEditMode = ({ commit, getters, dispatch }, force = false) => { export const toggleEditMode = ({ commit, getters, dispatch }, force = false) => {

View file

@ -1,13 +1,16 @@
import { normalizeHeaders } from '../../../lib/utils/common_utils';
import flash from '../../../flash'; import flash from '../../../flash';
import service from '../../services'; import service from '../../services';
import * as types from '../mutation_types'; import * as types from '../mutation_types';
import { import {
pushState,
setPageTitle,
createTemp, createTemp,
findIndexOfFile, findIndexOfFile,
} from '../utils'; } from '../utils';
export const closeFile = ({ commit, state, dispatch }, file) => { export const closeFile = ({ commit, state, dispatch }, { file, force = false }) => {
if (file.changed || file.tempFile) return; if ((file.changed || file.tempFile) && !force) return;
const indexOfClosedFile = findIndexOfFile(state.openFiles, file); const indexOfClosedFile = findIndexOfFile(state.openFiles, file);
const fileWasActive = file.active; const fileWasActive = file.active;
@ -20,12 +23,16 @@ export const closeFile = ({ commit, state, dispatch }, file) => {
const nextFileToOpen = state.openFiles[nextIndexToOpen]; const nextFileToOpen = state.openFiles[nextIndexToOpen];
dispatch('setFileActive', nextFileToOpen); dispatch('setFileActive', nextFileToOpen);
} else if (!state.openFiles.length) {
pushState(file.parentTreeUrl);
} }
}; };
export const setFileActive = ({ commit, state, getters, dispatch }, file) => { export const setFileActive = ({ commit, state, getters, dispatch }, file) => {
const currentActiveFile = getters.activeFile; const currentActiveFile = getters.activeFile;
if (file.active) return;
if (currentActiveFile) { if (currentActiveFile) {
commit(types.SET_FILE_ACTIVE, { file: currentActiveFile, active: false }); commit(types.SET_FILE_ACTIVE, { file: currentActiveFile, active: false });
} }
@ -34,17 +41,24 @@ export const setFileActive = ({ commit, state, getters, dispatch }, file) => {
dispatch('scrollToTab'); dispatch('scrollToTab');
}; };
export const getFileData = ({ commit, dispatch }, file) => { export const getFileData = ({ state, commit, dispatch }, file) => {
commit(types.TOGGLE_LOADING, file); commit(types.TOGGLE_LOADING, file);
service.getFileData(file.url) service.getFileData(file.url)
.then(res => res.json()) .then((res) => {
const pageTitle = decodeURI(normalizeHeaders(res.headers)['PAGE-TITLE']);
setPageTitle(pageTitle);
return res.json();
})
.then((data) => { .then((data) => {
commit(types.SET_FILE_DATA, { data, file }); commit(types.SET_FILE_DATA, { data, file });
commit(types.SET_PREVIEW_MODE);
commit(types.TOGGLE_FILE_OPEN, file); commit(types.TOGGLE_FILE_OPEN, file);
dispatch('setFileActive', file); dispatch('setFileActive', file);
commit(types.TOGGLE_LOADING, file); commit(types.TOGGLE_LOADING, file);
pushState(file.url);
}) })
.catch(() => { .catch(() => {
commit(types.TOGGLE_LOADING, file); commit(types.TOGGLE_LOADING, file);

View file

@ -93,6 +93,7 @@ export const createTempTree = ({ state, commit, dispatch }, name) => {
parent: tree, parent: tree,
tmpEntry, tmpEntry,
}); });
commit(types.TOGGLE_TREE_OPEN, tmpEntry);
tree = tmpEntry; tree = tmpEntry;
} else { } else {

View file

@ -14,7 +14,7 @@ export default {
onTopOfBranch: false, onTopOfBranch: false,
editMode: false, editMode: false,
loading: false, loading: false,
currentBlobView: '', currentBlobView: 'repo-preview',
discardPopupOpen: false, discardPopupOpen: false,
tree: [], tree: [],
openFiles: [], openFiles: [],

View file

@ -1,12 +1,10 @@
#repo{ data: { root: @path.empty?.to_s, #repo{ data: { root: @path.empty?.to_s,
root_url: project_tree_path(@project), root_url: project_tree_path(project),
url: content_url, url: content_url,
ref: @commit.id, ref: @commit.id,
project_name: project.name, project_name: project.name,
refs_url: refs_project_path(project, format: :json),
project_url: project_path(project), project_url: project_path(project),
project_id: project.id, project_id: project.id,
blob_url: namespace_project_blob_path(project.namespace, project, '{{branch}}'),
new_merge_request_url: namespace_project_new_merge_request_path(project.namespace, project, merge_request: { source_branch: '' }), new_merge_request_url: namespace_project_new_merge_request_path(project.namespace, project, merge_request: { source_branch: '' }),
can_commit: (!!can_push_branch?(project, @ref)).to_s, can_commit: (!!can_push_branch?(project, @ref)).to_s,
on_top_of_branch: (!!on_top_of_branch?(project, @ref)).to_s, on_top_of_branch: (!!on_top_of_branch?(project, @ref)).to_s,