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
0
Merge Requests
0
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
iv
gitlab-ce
Commits
f76a3f3d
Commit
f76a3f3d
authored
May 21, 2015
by
Robert Speicher
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add ZenMode javascript specs
parent
79aac2c1
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
79 additions
and
4 deletions
+79
-4
app/assets/javascripts/zen_mode.js.coffee
app/assets/javascripts/zen_mode.js.coffee
+9
-3
app/assets/stylesheets/generic/zen.scss
app/assets/stylesheets/generic/zen.scss
+9
-1
spec/javascripts/fixtures/zen_mode.html.haml
spec/javascripts/fixtures/zen_mode.html.haml
+9
-0
spec/javascripts/zen_mode_spec.js.coffee
spec/javascripts/zen_mode_spec.js.coffee
+52
-0
No files found.
app/assets/javascripts/zen_mode.js.coffee
View file @
f76a3f3d
#= require dropzone
#= require mousetrap
#= require mousetrap/pause
class
@
ZenMode
constructor
:
->
@
active_zen_area
=
null
...
...
@@ -26,7 +30,7 @@ class @ZenMode
@
exitZenMode
()
$
(
document
).
on
'keydown'
,
(
e
)
=>
if
e
.
keyCode
is
$
.
ui
.
keyCode
.
ESCAPE
if
e
.
keyCode
is
27
# Esc
@
exitZenMode
()
e
.
preventDefault
()
...
...
@@ -42,7 +46,9 @@ class @ZenMode
@
active_checkbox
.
prop
(
'checked'
,
false
)
@
active_zen_area
=
null
@
active_checkbox
=
null
window
.
location
.
hash
=
''
window
.
scrollTo
(
window
.
pageXOffset
,
@
scroll_position
)
@
restoreScroll
(
@
scroll_position
)
# Enable dropzone when leaving ZEN mode
Dropzone
.
forElement
(
'.div-dropzone'
).
enable
()
restoreScroll
:
(
y
)
->
window
.
scrollTo
(
window
.
pageXOffset
,
y
)
app/assets/stylesheets/generic/zen.scss
View file @
f76a3f3d
.zennable
{
position
:
relative
;
inpu
t
{
.zen-toggle-commen
t
{
display
:
none
;
}
...
...
@@ -26,10 +26,12 @@
}
}
// Hide the Enter link when we're in Zen mode
input
:checked
~
.zen-backdrop
.zen-enter-link
{
display
:
none
;
}
// Show the Leave link when we're in Zen mode
input
:checked
~
.zen-backdrop
.zen-leave-link
{
display
:
block
;
position
:
absolute
;
...
...
@@ -62,6 +64,9 @@
}
}
// Make the placeholder text in the standard textarea the same color as the
// background, effectively hiding it
.
zen-backdrop
textarea
:
:-
webkit-input-placeholder
{
color
:
white
;
}
...
...
@@ -78,6 +83,9 @@
color
:
white
;
}
// Make the color of the placeholder text in the Zenned-out textarea darker,
// so it becomes visible
input
:checked
~
.zen-backdrop
textarea
::-webkit-input-placeholder
{
color
:
#999
;
}
...
...
spec/javascripts/fixtures/zen_mode.html.haml
0 → 100644
View file @
f76a3f3d
.zennable
%input
#zen-toggle-comment
.zen-toggle-comment
{
tabindex:
'-1'
,
type:
'checkbox'
}
.zen-backdrop
%textarea
#note_note
.js-gfm-input.markdown-area
{
placeholder:
'Leave a comment'
}
%a
.zen-enter-link
{
tabindex:
'-1'
}
%i
.fa.fa-expand
Edit in fullscreen
%a
.zen-leave-link
%i
.fa.fa-compress
spec/javascripts/zen_mode_spec.js.coffee
0 → 100644
View file @
f76a3f3d
#= require zen_mode
describe
'ZenMode'
,
->
fixture
.
preload
(
'zen_mode.html'
)
beforeEach
->
fixture
.
load
(
'zen_mode.html'
)
# Stub Dropzone.forElement(...).enable()
spyOn
(
Dropzone
,
'forElement'
).
and
.
callFake
->
enable
:
->
true
@
zen
=
new
ZenMode
()
# Set this manually because we can't actually scroll the window
@
zen
.
scroll_position
=
456
# Ohmmmmmmm
enterZen
=
->
$
(
'.zen-toggle-comment'
).
prop
(
'checked'
,
true
).
trigger
(
'change'
)
# Wh- what was that?!
exitZen
=
->
$
(
'.zen-toggle-comment'
).
prop
(
'checked'
,
false
).
trigger
(
'change'
)
describe
'on enter'
,
->
it
'pauses Mousetrap'
,
->
spyOn
(
Mousetrap
,
'pause'
)
enterZen
()
expect
(
Mousetrap
.
pause
).
toHaveBeenCalled
()
describe
'in use'
,
->
beforeEach
->
enterZen
()
it
'exits on Escape'
,
->
$
(
document
).
trigger
(
jQuery
.
Event
(
'keydown'
,
{
keyCode
:
27
}))
expect
(
$
(
'.zen-toggle-comment'
).
prop
(
'checked'
)).
toBe
(
false
)
describe
'on exit'
,
->
beforeEach
->
enterZen
()
it
'unpauses Mousetrap'
,
->
spyOn
(
Mousetrap
,
'unpause'
)
exitZen
()
expect
(
Mousetrap
.
unpause
).
toHaveBeenCalled
()
it
'restores the scroll position'
,
->
spyOn
(
@
zen
,
'restoreScroll'
)
exitZen
()
expect
(
@
zen
.
restoreScroll
).
toHaveBeenCalledWith
(
456
)
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