Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
gitlab-ce
Commits
8f884cdc
Commit
8f884cdc
authored
Dec 10, 2020
by
Doug Stull
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Move group level visibilty to common area
- for reuse.
parent
fc7e85ae
Changes
10
Hide whitespace changes
Inline
Side-by-side
Showing
10 changed files
with
70 additions
and
57 deletions
+70
-57
app/assets/javascripts/groups/components/visibility_level_dropdown.vue
...vascripts/groups/components/visibility_level_dropdown.vue
+0
-0
app/assets/javascripts/groups/visibility_level.js
app/assets/javascripts/groups/visibility_level.js
+24
-0
app/helpers/visibility_level_helper.rb
app/helpers/visibility_level_helper.rb
+10
-0
app/views/shared/groups/_visibility_level.html.haml
app/views/shared/groups/_visibility_level.html.haml
+3
-0
ee/app/assets/javascripts/registrations/groups/new/index.js
ee/app/assets/javascripts/registrations/groups/new/index.js
+1
-19
ee/app/helpers/ee/registrations_helper.rb
ee/app/helpers/ee/registrations_helper.rb
+0
-10
ee/app/views/registrations/groups/new.html.haml
ee/app/views/registrations/groups/new.html.haml
+1
-3
ee/spec/helpers/ee/registrations_helper_spec.rb
ee/spec/helpers/ee/registrations_helper_spec.rb
+0
-24
spec/frontend/groups/components/visibility_level_dropdown_spec.js
...ntend/groups/components/visibility_level_dropdown_spec.js
+1
-1
spec/helpers/visibility_level_helper_spec.rb
spec/helpers/visibility_level_helper_spec.rb
+30
-0
No files found.
ee/app/assets/javascripts/registration
s/components/visibility_level_dropdown.vue
→
app/assets/javascripts/group
s/components/visibility_level_dropdown.vue
View file @
8f884cdc
File moved
app/assets/javascripts/groups/visibility_level.js
0 → 100644
View file @
8f884cdc
import
Vue
from
'
vue
'
;
import
VisibilityLevelDropdown
from
'
./components/visibility_level_dropdown.vue
'
;
export
default
()
=>
{
const
el
=
document
.
querySelector
(
'
.js-visibility-level-dropdown
'
);
if
(
!
el
)
{
return
null
;
}
const
{
visibilityLevelOptions
,
defaultLevel
}
=
el
.
dataset
;
return
new
Vue
({
el
,
render
(
createElement
)
{
return
createElement
(
VisibilityLevelDropdown
,
{
props
:
{
visibilityLevelOptions
:
JSON
.
parse
(
visibilityLevelOptions
),
defaultLevel
:
Number
(
defaultLevel
),
},
});
},
});
};
app/helpers/visibility_level_helper.rb
View file @
8f884cdc
...
@@ -157,6 +157,16 @@ module VisibilityLevelHelper
...
@@ -157,6 +157,16 @@ module VisibilityLevelHelper
end
end
end
end
def
visibility_level_options
(
form_model
)
available_visibility_levels
(
form_model
).
map
do
|
level
|
{
level:
level
,
label:
visibility_level_label
(
level
),
description:
visibility_level_description
(
level
,
form_model
)
}
end
end
def
snippets_selected_visibility_level
(
visibility_levels
,
selected
)
def
snippets_selected_visibility_level
(
visibility_levels
,
selected
)
visibility_levels
.
find
{
|
level
|
level
==
selected
}
||
visibility_levels
.
min
visibility_levels
.
find
{
|
level
|
level
==
selected
}
||
visibility_levels
.
min
end
end
...
...
app/views/shared/groups/_visibility_level.html.haml
0 → 100644
View file @
8f884cdc
=
f
.
label
:visibility_level
,
class:
'label-bold'
do
=
_
(
'Visibility level'
)
.js-visibility-level-dropdown
{
data:
{
visibility_level_options:
visibility_level_options
(
@group
).
to_json
,
default_level:
f
.
object
.
visibility_level
}
}
ee/app/assets/javascripts/registrations/groups/new/index.js
View file @
8f884cdc
import
Vue
from
'
vue
'
;
import
Vue
from
'
vue
'
;
import
mountInviteMembers
from
'
ee/groups/invite
'
;
import
mountInviteMembers
from
'
ee/groups/invite
'
;
import
mountVisibilityLevelDropdown
from
'
~/groups/visibility_level
'
;
import
{
STEPS
,
ONBOARDING_ISSUES_EXPERIMENT_FLOW_STEPS
}
from
'
../../constants
'
;
import
{
STEPS
,
ONBOARDING_ISSUES_EXPERIMENT_FLOW_STEPS
}
from
'
../../constants
'
;
import
ProgressBar
from
'
../../components/progress_bar.vue
'
;
import
ProgressBar
from
'
../../components/progress_bar.vue
'
;
import
VisibilityLevelDropdown
from
'
../../components/visibility_level_dropdown.vue
'
;
function
mountProgressBar
()
{
function
mountProgressBar
()
{
const
el
=
document
.
getElementById
(
'
progress-bar
'
);
const
el
=
document
.
getElementById
(
'
progress-bar
'
);
...
@@ -19,24 +19,6 @@ function mountProgressBar() {
...
@@ -19,24 +19,6 @@ function mountProgressBar() {
});
});
}
}
function
mountVisibilityLevelDropdown
()
{
const
el
=
document
.
querySelector
(
'
.js-visibility-level-dropdown
'
);
if
(
!
el
)
return
null
;
return
new
Vue
({
el
,
render
(
createElement
)
{
return
createElement
(
VisibilityLevelDropdown
,
{
props
:
{
visibilityLevelOptions
:
JSON
.
parse
(
el
.
dataset
.
visibilityLevelOptions
),
defaultLevel
:
Number
(
el
.
dataset
.
defaultLevel
),
},
});
},
});
}
export
default
()
=>
{
export
default
()
=>
{
mountProgressBar
();
mountProgressBar
();
mountVisibilityLevelDropdown
();
mountVisibilityLevelDropdown
();
...
...
ee/app/helpers/ee/registrations_helper.rb
View file @
8f884cdc
...
@@ -4,16 +4,6 @@ module EE
...
@@ -4,16 +4,6 @@ module EE
module
RegistrationsHelper
module
RegistrationsHelper
include
::
Gitlab
::
Utils
::
StrongMemoize
include
::
Gitlab
::
Utils
::
StrongMemoize
def
visibility_level_options
available_visibility_levels
(
@group
).
map
do
|
level
|
{
level:
level
,
label:
visibility_level_label
(
level
),
description:
visibility_level_description
(
level
,
@group
)
}
end
end
private
private
def
redirect_path
def
redirect_path
...
...
ee/app/views/registrations/groups/new.html.haml
View file @
8f884cdc
...
@@ -39,9 +39,7 @@
...
@@ -39,9 +39,7 @@
%p
.validation-pending.gl-field-error-ignore.field-validation.hide
=
_
(
'Checking group path availability...'
)
%p
.validation-pending.gl-field-error-ignore.field-validation.hide
=
_
(
'Checking group path availability...'
)
.row
.row
.form-group.col-sm-12
.form-group.col-sm-12
=
f
.
label
:visibility_level
,
class:
'label-bold'
do
=
render
partial:
'shared/groups/visibility_level'
,
locals:
{
f:
f
}
=
_
(
'Visibility level'
)
.js-visibility-level-dropdown
{
data:
{
visibility_level_options:
visibility_level_options
.
to_json
,
default_level:
f
.
object
.
visibility_level
}
}
=
render
partial:
'shared/groups/invite_members'
=
render
partial:
'shared/groups/invite_members'
.row
.row
.form-group.col-sm-12.mb-0
.form-group.col-sm-12.mb-0
...
...
ee/spec/helpers/ee/registrations_helper_spec.rb
deleted
100644 → 0
View file @
fc7e85ae
# frozen_string_literal: true
require
'spec_helper'
RSpec
.
describe
EE
::
RegistrationsHelper
do
using
RSpec
::
Parameterized
::
TableSyntax
describe
'#visibility_level_options'
do
let
(
:user
)
{
build
(
:user
)
}
before
do
allow
(
helper
).
to
receive
(
:current_user
).
and_return
(
user
)
assign
(
:group
,
Group
.
new
)
end
it
'returns the desired mapping'
do
expect
(
helper
.
visibility_level_options
).
to
eq
[
{
level:
0
,
label:
'Private'
,
description:
'The group and its projects can only be viewed by members.'
},
{
level:
10
,
label:
'Internal'
,
description:
'The group and any internal projects can be viewed by any logged in user except external users.'
},
{
level:
20
,
label:
'Public'
,
description:
'The group and any public projects can be viewed without any authentication.'
}
]
end
end
end
ee/spec/frontend/registration
s/components/visibility_level_dropdown_spec.js
→
spec/frontend/group
s/components/visibility_level_dropdown_spec.js
View file @
8f884cdc
import
{
GlDropdown
,
GlDropdownItem
}
from
'
@gitlab/ui
'
;
import
{
GlDropdown
,
GlDropdownItem
}
from
'
@gitlab/ui
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
Component
from
'
ee/registration
s/components/visibility_level_dropdown.vue
'
;
import
Component
from
'
~/group
s/components/visibility_level_dropdown.vue
'
;
describe
(
'
Visibility Level Dropdown
'
,
()
=>
{
describe
(
'
Visibility Level Dropdown
'
,
()
=>
{
let
wrapper
;
let
wrapper
;
...
...
spec/helpers/visibility_level_helper_spec.rb
View file @
8f884cdc
...
@@ -284,4 +284,34 @@ RSpec.describe VisibilityLevelHelper do
...
@@ -284,4 +284,34 @@ RSpec.describe VisibilityLevelHelper do
it
{
is_expected
.
to
eq
(
expected
)
}
it
{
is_expected
.
to
eq
(
expected
)
}
end
end
end
end
describe
'#visibility_level_options'
do
let
(
:user
)
{
build
(
:user
)
}
before
do
allow
(
helper
).
to
receive
(
:current_user
).
and_return
(
user
)
end
it
'returns the desired mapping'
do
expected_options
=
[
{
level:
0
,
label:
'Private'
,
description:
'The group and its projects can only be viewed by members.'
},
{
level:
10
,
label:
'Internal'
,
description:
'The group and any internal projects can be viewed by any logged in user except external users.'
},
{
level:
20
,
label:
'Public'
,
description:
'The group and any public projects can be viewed without any authentication.'
}
]
expect
(
helper
.
visibility_level_options
(
group
)).
to
eq
expected_options
end
end
end
end
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment