Commit 9f03680e authored by Phil Hughes's avatar Phil Hughes

Moved IDE into EE folder

parent 6d49d141
...@@ -324,10 +324,6 @@ module ApplicationHelper ...@@ -324,10 +324,6 @@ module ApplicationHelper
cookies["sidebar_collapsed"] == "true" cookies["sidebar_collapsed"] == "true"
end end
def show_new_ide?(project)
cookies["new_repo"] == "true" && project.feature_available?(:ide)
end
def locale_path def locale_path
asset_path("locale/#{Gitlab::I18n.locale}/app.js") asset_path("locale/#{Gitlab::I18n.locale}/app.js")
end end
......
...@@ -33,20 +33,6 @@ module BlobHelper ...@@ -33,20 +33,6 @@ module BlobHelper
ref) ref)
end end
def ide_edit_button(project = @project, ref = @ref, path = @path, options = {})
return unless show_new_ide?(project)
return unless blob = readable_blob(options, path, project, ref)
common_classes = "btn js-edit-ide #{options[:extra_class]}"
edit_button_tag(blob,
common_classes,
_('Web IDE'),
ide_edit_path(project, ref, path, options),
project,
ref)
end
def modify_file_button(project = @project, ref = @ref, path = @path, label:, action:, btn_class:, modal_type:) def modify_file_button(project = @project, ref = @ref, path = @path, label:, action:, btn_class:, modal_type:)
return unless current_user return unless current_user
......
...@@ -78,9 +78,11 @@ ...@@ -78,9 +78,11 @@
= render 'projects/find_file_link' = render 'projects/find_file_link'
-## EE-specific
- if show_new_ide?(@project) - if show_new_ide?(@project)
= succeed " " do = succeed " " do
= link_to ide_edit_path(@project, @id), class: 'btn btn-default' do = link_to ide_edit_path(@project, @id), class: 'btn btn-default' do
= _('Web IDE') = _('Web IDE')
-## EE-specific
= render 'projects/buttons/download', project: @project, ref: @ref = render 'projects/buttons/download', project: @project, ref: @ref
...@@ -58,8 +58,6 @@ Rails.application.routes.draw do ...@@ -58,8 +58,6 @@ Rails.application.routes.draw do
get 'liveness' => 'health#liveness' get 'liveness' => 'health#liveness'
get 'readiness' => 'health#readiness' get 'readiness' => 'health#readiness'
post 'storage_check' => 'health#storage_check' post 'storage_check' => 'health#storage_check'
get 'ide' => 'ide#index'
get 'ide/*vueroute' => 'ide#index', format: false
resources :metrics, only: [:index] resources :metrics, only: [:index]
mount Peek::Railtie => '/peek' mount Peek::Railtie => '/peek'
...@@ -78,6 +76,11 @@ Rails.application.routes.draw do ...@@ -78,6 +76,11 @@ Rails.application.routes.draw do
# UserCallouts # UserCallouts
resources :user_callouts, only: [:create] resources :user_callouts, only: [:create]
## EE-specific
get 'ide' => 'ide#index'
get 'ide/*vueroute' => 'ide#index', format: false
## EE-specific
end end
# Koding route # Koding route
......
module IdeHelper
def show_new_ide?(project)
cookies["new_repo"] == "true" && project.feature_available?(:ide)
end
def ide_edit_button(project = @project, ref = @ref, path = @path, options = {})
return unless show_new_ide?(project)
return unless blob = readable_blob(options, path, project, ref)
common_classes = "btn js-edit-ide #{options[:extra_class]}"
edit_button_tag(blob,
common_classes,
_('Web IDE'),
ide_edit_path(project, ref, path, options),
project,
ref)
end
end
import Vue from 'vue'; import Vue from 'vue';
import store from '~/ide/stores'; import store from 'ee/ide/stores';
import commitActions from 'ee/ide/components/commit_sidebar/actions.vue'; import commitActions from 'ee/ide/components/commit_sidebar/actions.vue';
import { createComponentWithStore } from 'spec/helpers/vue_mount_component_helper'; import { createComponentWithStore } from 'spec/helpers/vue_mount_component_helper';
import { resetStore } from 'spec/repo/helpers'; import { resetStore } from 'spec/repo/helpers';
......
import Vue from 'vue'; import Vue from 'vue';
import store from '~/ide/stores'; import store from 'ee/ide/stores';
import listCollapsed from '~/ide/components/commit_sidebar/list_collapsed.vue'; import listCollapsed from 'ee/ide/components/commit_sidebar/list_collapsed.vue';
import { createComponentWithStore } from 'spec/helpers/vue_mount_component_helper'; import { createComponentWithStore } from 'spec/helpers/vue_mount_component_helper';
import { file } from '../../helpers'; import { file } from '../../helpers';
......
import Vue from 'vue'; import Vue from 'vue';
import listItem from '~/ide/components/commit_sidebar/list_item.vue'; import listItem from 'ee/ide/components/commit_sidebar/list_item.vue';
import router from '~/ide/ide_router'; import router from 'ee/ide/ide_router';
import mountComponent from 'spec/helpers/vue_mount_component_helper'; import mountComponent from 'spec/helpers/vue_mount_component_helper';
import { file } from '../../helpers'; import { file } from '../../helpers';
......
import Vue from 'vue'; import Vue from 'vue';
import store from '~/ide/stores'; import store from 'ee/ide/stores';
import commitSidebarList from '~/ide/components/commit_sidebar/list.vue'; import commitSidebarList from 'ee/ide/components/commit_sidebar/list.vue';
import { createComponentWithStore } from 'spec/helpers/vue_mount_component_helper'; import { createComponentWithStore } from 'spec/helpers/vue_mount_component_helper';
import { file } from '../../helpers'; import { file } from '../../helpers';
......
import Vue from 'vue'; import Vue from 'vue';
import store from '~/ide/stores'; import store from 'ee/ide/stores';
import radioGroup from 'ee/ide/components/commit_sidebar/radio_group.vue'; import radioGroup from 'ee/ide/components/commit_sidebar/radio_group.vue';
import { createComponentWithStore } from 'spec/helpers/vue_mount_component_helper'; import { createComponentWithStore } from 'spec/helpers/vue_mount_component_helper';
import { resetStore } from 'spec/repo/helpers'; import { resetStore } from 'spec/repo/helpers';
......
import Vue from 'vue'; import Vue from 'vue';
import store from '~/ide/stores'; import store from 'ee/ide/stores';
import ideContextBar from '~/ide/components/ide_context_bar.vue'; import ideContextBar from 'ee/ide/components/ide_context_bar.vue';
import { createComponentWithStore } from 'spec/helpers/vue_mount_component_helper'; import { createComponentWithStore } from 'spec/helpers/vue_mount_component_helper';
describe('Multi-file editor right context bar', () => { describe('Multi-file editor right context bar', () => {
......
import Vue from 'vue'; import Vue from 'vue';
import store from '~/ide/stores'; import store from 'ee/ide/stores';
import ideRepoTree from '~/ide/components/ide_repo_tree.vue'; import ideRepoTree from 'ee/ide/components/ide_repo_tree.vue';
import { file, resetStore } from '../helpers'; import { file, resetStore } from '../helpers';
describe('IdeRepoTree', () => { describe('IdeRepoTree', () => {
......
import Vue from 'vue'; import Vue from 'vue';
import store from '~/ide/stores'; import store from 'ee/ide/stores';
import ideSidebar from '~/ide/components/ide_side_bar.vue'; import ideSidebar from 'ee/ide/components/ide_side_bar.vue';
import { createComponentWithStore } from 'spec/helpers/vue_mount_component_helper'; import { createComponentWithStore } from 'spec/helpers/vue_mount_component_helper';
import { resetStore } from '../helpers'; import { resetStore } from '../helpers';
......
import Vue from 'vue'; import Vue from 'vue';
import store from '~/ide/stores'; import store from 'ee/ide/stores';
import ide from '~/ide/components/ide.vue'; import ide from 'ee/ide/components/ide.vue';
import { createComponentWithStore } from 'spec/helpers/vue_mount_component_helper'; import { createComponentWithStore } from 'spec/helpers/vue_mount_component_helper';
import { file, resetStore } from '../helpers'; import { file, resetStore } from '../helpers';
......
import Vue from 'vue'; import Vue from 'vue';
import store from '~/ide/stores'; import store from 'ee/ide/stores';
import newBranchForm from '~/ide/components/new_branch_form.vue'; import newBranchForm from 'ee/ide/components/new_branch_form.vue';
import { createComponentWithStore } from 'spec/helpers/vue_mount_component_helper'; import { createComponentWithStore } from 'spec/helpers/vue_mount_component_helper';
import { resetStore } from '../helpers'; import { resetStore } from '../helpers';
......
import Vue from 'vue'; import Vue from 'vue';
import store from '~/ide/stores'; import store from 'ee/ide/stores';
import newDropdown from '~/ide/components/new_dropdown/index.vue'; import newDropdown from 'ee/ide/components/new_dropdown/index.vue';
import { createComponentWithStore } from 'spec/helpers/vue_mount_component_helper'; import { createComponentWithStore } from 'spec/helpers/vue_mount_component_helper';
import { resetStore } from '../../helpers'; import { resetStore } from '../../helpers';
......
import Vue from 'vue'; import Vue from 'vue';
import store from '~/ide/stores'; import store from 'ee/ide/stores';
import service from '~/ide/services'; import service from 'ee/ide/services';
import modal from '~/ide/components/new_dropdown/modal.vue'; import modal from 'ee/ide/components/new_dropdown/modal.vue';
import { createComponentWithStore } from 'spec/helpers/vue_mount_component_helper'; import { createComponentWithStore } from 'spec/helpers/vue_mount_component_helper';
import { file, resetStore } from '../../helpers'; import { file, resetStore } from '../../helpers';
......
import Vue from 'vue'; import Vue from 'vue';
import upload from '~/ide/components/new_dropdown/upload.vue'; import upload from 'ee/ide/components/new_dropdown/upload.vue';
import store from '~/ide/stores'; import store from 'ee/ide/stores';
import service from '~/ide/services'; import service from 'ee/ide/services';
import { createComponentWithStore } from 'spec/helpers/vue_mount_component_helper'; import { createComponentWithStore } from 'spec/helpers/vue_mount_component_helper';
import { resetStore } from '../../helpers'; import { resetStore } from '../../helpers';
......
import Vue from 'vue'; import Vue from 'vue';
import store from '~/ide/stores'; import store from 'ee/ide/stores';
import service from '~/ide/services'; import service from 'ee/ide/services';
import repoCommitSection from '~/ide/components/repo_commit_section.vue'; import repoCommitSection from 'ee/ide/components/repo_commit_section.vue';
import { createComponentWithStore } from 'spec/helpers/vue_mount_component_helper'; import { createComponentWithStore } from 'spec/helpers/vue_mount_component_helper';
import getSetTimeoutPromise from 'spec/helpers/set_timeout_promise_helper'; import getSetTimeoutPromise from 'spec/helpers/set_timeout_promise_helper';
import { file, resetStore } from '../helpers'; import { file, resetStore } from '../helpers';
......
import Vue from 'vue'; import Vue from 'vue';
import store from '~/ide/stores'; import store from 'ee/ide/stores';
import repoEditButton from '~/ide/components/repo_edit_button.vue'; import repoEditButton from 'ee/ide/components/repo_edit_button.vue';
import { file, resetStore } from '../helpers'; import { file, resetStore } from '../helpers';
describe('RepoEditButton', () => { describe('RepoEditButton', () => {
......
import Vue from 'vue'; import Vue from 'vue';
import store from '~/ide/stores'; import store from 'ee/ide/stores';
import repoEditor from '~/ide/components/repo_editor.vue'; import repoEditor from 'ee/ide/components/repo_editor.vue';
import monacoLoader from '~/ide/monaco_loader'; import monacoLoader from 'ee/ide/monaco_loader';
import { file, resetStore } from '../helpers'; import { file, resetStore } from '../helpers';
describe('RepoEditor', () => { describe('RepoEditor', () => {
......
import Vue from 'vue'; import Vue from 'vue';
import store from '~/ide/stores'; import store from 'ee/ide/stores';
import repoFileButtons from '~/ide/components/repo_file_buttons.vue'; import repoFileButtons from 'ee/ide/components/repo_file_buttons.vue';
import { file, resetStore } from '../helpers'; import { file, resetStore } from '../helpers';
describe('RepoFileButtons', () => { describe('RepoFileButtons', () => {
......
import Vue from 'vue'; import Vue from 'vue';
import store from '~/ide/stores'; import store from 'ee/ide/stores';
import repoFile from '~/ide/components/repo_file.vue'; import repoFile from 'ee/ide/components/repo_file.vue';
import { file, resetStore } from '../helpers'; import { file, resetStore } from '../helpers';
describe('RepoFile', () => { describe('RepoFile', () => {
......
import Vue from 'vue'; import Vue from 'vue';
import store from '~/ide/stores'; import store from 'ee/ide/stores';
import repoLoadingFile from '~/ide/components/repo_loading_file.vue'; import repoLoadingFile from 'ee/ide/components/repo_loading_file.vue';
import { resetStore } from '../helpers'; import { resetStore } from '../helpers';
describe('RepoLoadingFile', () => { describe('RepoLoadingFile', () => {
......
import Vue from 'vue'; import Vue from 'vue';
import store from '~/ide/stores'; import store from 'ee/ide/stores';
import repoPrevDirectory from '~/ide/components/repo_prev_directory.vue'; import repoPrevDirectory from 'ee/ide/components/repo_prev_directory.vue';
import { resetStore } from '../helpers'; import { resetStore } from '../helpers';
describe('RepoPrevDirectory', () => { describe('RepoPrevDirectory', () => {
......
import Vue from 'vue'; import Vue from 'vue';
import store from '~/ide/stores'; import store from 'ee/ide/stores';
import repoPreview from '~/ide/components/repo_preview.vue'; import repoPreview from 'ee/ide/components/repo_preview.vue';
import { file, resetStore } from '../helpers'; import { file, resetStore } from '../helpers';
describe('RepoPreview', () => { describe('RepoPreview', () => {
......
import Vue from 'vue'; import Vue from 'vue';
import store from '~/ide/stores'; import store from 'ee/ide/stores';
import repoTab from '~/ide/components/repo_tab.vue'; import repoTab from 'ee/ide/components/repo_tab.vue';
import { file, resetStore } from '../helpers'; import { file, resetStore } from '../helpers';
describe('RepoTab', () => { describe('RepoTab', () => {
......
import Vue from 'vue'; import Vue from 'vue';
import store from '~/ide/stores'; import store from 'ee/ide/stores';
import repoTabs from '~/ide/components/repo_tabs.vue'; import repoTabs from 'ee/ide/components/repo_tabs.vue';
import { file, resetStore } from '../helpers'; import { file, resetStore } from '../helpers';
describe('RepoTabs', () => { describe('RepoTabs', () => {
......
import { decorateData } from '~/ide/stores/utils'; import { decorateData } from 'ee/ide/stores/utils';
import state from '~/ide/stores/state'; import state from 'ee/ide/stores/state';
import commitState from 'ee/ide/stores/modules/commit/state'; import commitState from 'ee/ide/stores/modules/commit/state';
export const resetStore = (store) => { export const resetStore = (store) => {
......
import Disposable from '~/ide/lib/common/disposable'; import Disposable from 'ee/ide/lib/common/disposable';
describe('Multi-file editor library disposable class', () => { describe('Multi-file editor library disposable class', () => {
let instance; let instance;
......
/* global monaco */ /* global monaco */
import monacoLoader from '~/ide/monaco_loader'; import monacoLoader from 'ee/ide/monaco_loader';
import ModelManager from '~/ide/lib/common/model_manager'; import ModelManager from 'ee/ide/lib/common/model_manager';
import { file } from '../../helpers'; import { file } from '../../helpers';
describe('Multi-file editor library model manager', () => { describe('Multi-file editor library model manager', () => {
......
/* global monaco */ /* global monaco */
import monacoLoader from '~/ide/monaco_loader'; import monacoLoader from 'ee/ide/monaco_loader';
import Model from '~/ide/lib/common/model'; import Model from 'ee/ide/lib/common/model';
import { file } from '../../helpers'; import { file } from '../../helpers';
describe('Multi-file editor library model', () => { describe('Multi-file editor library model', () => {
......
/* global monaco */ /* global monaco */
import monacoLoader from '~/ide/monaco_loader'; import monacoLoader from 'ee/ide/monaco_loader';
import editor from '~/ide/lib/editor'; import editor from 'ee/ide/lib/editor';
import DecorationsController from '~/ide/lib/decorations/controller'; import DecorationsController from 'ee/ide/lib/decorations/controller';
import Model from '~/ide/lib/common/model'; import Model from 'ee/ide/lib/common/model';
import { file } from '../../helpers'; import { file } from '../../helpers';
describe('Multi-file editor library decorations controller', () => { describe('Multi-file editor library decorations controller', () => {
......
/* global monaco */ /* global monaco */
import monacoLoader from '~/ide/monaco_loader'; import monacoLoader from 'ee/ide/monaco_loader';
import editor from '~/ide/lib/editor'; import editor from 'ee/ide/lib/editor';
import ModelManager from '~/ide/lib/common/model_manager'; import ModelManager from 'ee/ide/lib/common/model_manager';
import DecorationsController from '~/ide/lib/decorations/controller'; import DecorationsController from 'ee/ide/lib/decorations/controller';
import DirtyDiffController, { getDiffChangeType, getDecorator } from '~/ide/lib/diff/controller'; import DirtyDiffController, { getDiffChangeType, getDecorator } from 'ee/ide/lib/diff/controller';
import { computeDiff } from '~/ide/lib/diff/diff'; import { computeDiff } from 'ee/ide/lib/diff/diff';
import { file } from '../../helpers'; import { file } from '../../helpers';
describe('Multi-file editor library dirty diff controller', () => { describe('Multi-file editor library dirty diff controller', () => {
......
import { computeDiff } from '~/ide/lib/diff/diff'; import { computeDiff } from 'ee/ide/lib/diff/diff';
describe('Multi-file editor library diff calculator', () => { describe('Multi-file editor library diff calculator', () => {
describe('computeDiff', () => { describe('computeDiff', () => {
......
import editorOptions from '~/ide/lib/editor_options'; import editorOptions from 'ee/ide/lib/editor_options';
describe('Multi-file editor library editor options', () => { describe('Multi-file editor library editor options', () => {
it('returns an array', () => { it('returns an array', () => {
......
/* global monaco */ /* global monaco */
import monacoLoader from '~/ide/monaco_loader'; import monacoLoader from 'ee/ide/monaco_loader';
import editor from '~/ide/lib/editor'; import editor from 'ee/ide/lib/editor';
import { file } from '../helpers'; import { file } from '../helpers';
describe('Multi-file editor library', () => { describe('Multi-file editor library', () => {
......
import monacoContext from 'monaco-editor/dev/vs/loader'; import monacoContext from 'monaco-editor/dev/vs/loader';
import monacoLoader from '~/ide/monaco_loader'; import monacoLoader from 'ee/ide/monaco_loader';
describe('MonacoLoader', () => { describe('MonacoLoader', () => {
it('calls require.config and exports require', () => { it('calls require.config and exports require', () => {
......
import store from '~/ide/stores'; import store from 'ee/ide/stores';
import service from '~/ide/services'; import service from 'ee/ide/services';
import { resetStore } from '../../helpers'; import { resetStore } from '../../helpers';
describe('Multi-file store branch actions', () => { describe('Multi-file store branch actions', () => {
......
import Vue from 'vue'; import Vue from 'vue';
import store from '~/ide/stores'; import store from 'ee/ide/stores';
import service from '~/ide/services'; import service from 'ee/ide/services';
import { file, resetStore } from '../../helpers'; import { file, resetStore } from '../../helpers';
describe('Multi-file store file actions', () => { describe('Multi-file store file actions', () => {
......
import Vue from 'vue'; import Vue from 'vue';
import store from '~/ide/stores'; import store from 'ee/ide/stores';
import service from '~/ide/services'; import service from 'ee/ide/services';
import { file, resetStore } from '../../helpers'; import { file, resetStore } from '../../helpers';
describe('Multi-file store tree actions', () => { describe('Multi-file store tree actions', () => {
......
import Vue from 'vue'; import Vue from 'vue';
import * as urlUtils from '~/lib/utils/url_utility'; import * as urlUtils from '~/lib/utils/url_utility';
import store from '~/ide/stores'; import store from 'ee/ide/stores';
import { resetStore, file } from '../helpers'; import { resetStore, file } from '../helpers';
describe('Multi-file store actions', () => { describe('Multi-file store actions', () => {
......
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