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
a4ed1008
Commit
a4ed1008
authored
Mar 03, 2017
by
Eric Eastwood
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fix wrong image src with cached gl-emoji and relative root
parent
ef81768e
Changes
6
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
21 additions
and
27 deletions
+21
-27
app/assets/javascripts/behaviors/gl_emoji.js
app/assets/javascripts/behaviors/gl_emoji.js
+14
-3
lib/gitlab/emoji.rb
lib/gitlab/emoji.rb
+3
-3
lib/gitlab/gon_helper.rb
lib/gitlab/gon_helper.rb
+1
-0
spec/helpers/gitlab_markdown_helper_spec.rb
spec/helpers/gitlab_markdown_helper_spec.rb
+1
-1
spec/lib/banzai/filter/emoji_filter_spec.rb
spec/lib/banzai/filter/emoji_filter_spec.rb
+0
-19
spec/support/matchers/markdown_matchers.rb
spec/support/matchers/markdown_matchers.rb
+2
-1
No files found.
app/assets/javascripts/behaviors/gl_emoji.js
View file @
a4ed1008
...
@@ -10,6 +10,14 @@ function emojiImageTag(name, src) {
...
@@ -10,6 +10,14 @@ function emojiImageTag(name, src) {
return
`<img class="emoji" title=":
${
name
}
:" alt=":
${
name
}
:" src="
${
src
}
" width="20" height="20" align="absmiddle" />`
;
return
`<img class="emoji" title=":
${
name
}
:" alt=":
${
name
}
:" src="
${
src
}
" width="20" height="20" align="absmiddle" />`
;
}
}
function
assembleFallbackImageSrc
(
inputName
)
{
const
name
=
Object
.
prototype
.
hasOwnProperty
.
call
(
emojiAliases
,
inputName
)
?
emojiAliases
[
inputName
]
:
inputName
;
const
emojiInfo
=
emojiMap
[
name
];
const
fallbackImageSrc
=
`
${
gon
.
asset_host
||
''
}${
gon
.
relative_url_root
||
''
}
/assets/emoji/
${
name
}
-
${
emojiInfo
.
digest
}
.png`
;
return
fallbackImageSrc
;
}
const
glEmojiTagDefaults
=
{
const
glEmojiTagDefaults
=
{
sprite
:
false
,
sprite
:
false
,
forceFallback
:
false
,
forceFallback
:
false
,
...
@@ -19,7 +27,7 @@ function glEmojiTag(inputName, options) {
...
@@ -19,7 +27,7 @@ function glEmojiTag(inputName, options) {
const
name
=
Object
.
prototype
.
hasOwnProperty
.
call
(
emojiAliases
,
inputName
)
?
const
name
=
Object
.
prototype
.
hasOwnProperty
.
call
(
emojiAliases
,
inputName
)
?
emojiAliases
[
inputName
]
:
inputName
;
emojiAliases
[
inputName
]
:
inputName
;
const
emojiInfo
=
emojiMap
[
name
];
const
emojiInfo
=
emojiMap
[
name
];
const
fallbackImageSrc
=
`
${
gon
.
relative_url_root
||
''
}
/assets/emoji/
${
name
}
-
${
emojiInfo
.
digest
}
.png`
;
const
fallbackImageSrc
=
assembleFallbackImageSrc
(
name
)
;
const
fallbackSpriteClass
=
`emoji-
${
name
}
`
;
const
fallbackSpriteClass
=
`emoji-
${
name
}
`
;
const
classList
=
[];
const
classList
=
[];
...
@@ -162,6 +170,7 @@ const GlEmojiElementProto = Object.create(HTMLElement.prototype);
...
@@ -162,6 +170,7 @@ const GlEmojiElementProto = Object.create(HTMLElement.prototype);
GlEmojiElementProto
.
createdCallback
=
function
createdCallback
()
{
GlEmojiElementProto
.
createdCallback
=
function
createdCallback
()
{
const
emojiUnicode
=
this
.
textContent
.
trim
();
const
emojiUnicode
=
this
.
textContent
.
trim
();
const
{
const
{
name
,
unicodeVersion
,
unicodeVersion
,
fallbackSrc
,
fallbackSrc
,
fallbackSpriteClass
,
fallbackSpriteClass
,
...
@@ -184,8 +193,10 @@ GlEmojiElementProto.createdCallback = function createdCallback() {
...
@@ -184,8 +193,10 @@ GlEmojiElementProto.createdCallback = function createdCallback() {
this
.
classList
.
add
(
'
emoji-icon
'
);
this
.
classList
.
add
(
'
emoji-icon
'
);
this
.
classList
.
add
(
fallbackSpriteClass
);
this
.
classList
.
add
(
fallbackSpriteClass
);
}
else
if
(
hasImageFallback
)
{
}
else
if
(
hasImageFallback
)
{
const
emojiName
=
this
.
dataset
.
name
;
this
.
innerHTML
=
emojiImageTag
(
name
,
fallbackSrc
);
this
.
innerHTML
=
emojiImageTag
(
emojiName
,
fallbackSrc
);
}
else
{
const
src
=
assembleFallbackImageSrc
(
name
);
this
.
innerHTML
=
emojiImageTag
(
name
,
src
);
}
}
}
}
};
};
...
...
lib/gitlab/emoji.rb
View file @
a4ed1008
...
@@ -41,12 +41,12 @@ module Gitlab
...
@@ -41,12 +41,12 @@ module Gitlab
end
end
# CSS sprite fallback takes precedence over image fallback
# CSS sprite fallback takes precedence over image fallback
def
gl_emoji_tag
(
name
,
sprite:
false
,
force_fallback:
false
)
def
gl_emoji_tag
(
name
,
image:
false
,
sprite:
false
,
force_fallback:
false
)
emoji_name
=
emojis_aliases
[
name
]
||
name
emoji_name
=
emojis_aliases
[
name
]
||
name
emoji_info
=
emojis
[
emoji_name
]
emoji_info
=
emojis
[
emoji_name
]
emoji_fallback_image_source
=
ActionController
::
Base
.
helpers
.
asset_url
(
"emoji/
#{
emoji_info
[
'name'
]
}
.png"
)
emoji_fallback_image_source
=
ActionController
::
Base
.
helpers
.
url_to_image
(
"emoji/
#{
emoji_info
[
'name'
]
}
.png"
)
emoji_fallback_sprite_class
=
"emoji-
#{
emoji_name
}
"
emoji_fallback_sprite_class
=
"emoji-
#{
emoji_name
}
"
"<gl-emoji
#{
force_fallback
&&
sprite
?
"class='emoji-icon
#{
emoji_fallback_sprite_class
}
'"
:
""
}
data-name='
#{
emoji_name
}
'
data-fallback-src='
#{
emoji_fallback_image_source
}
'
#{
sprite
?
"data-fallback-sprite-class='
#{
emoji_fallback_sprite_class
}
'"
:
""
}
data-unicode-version='
#{
emoji_unicode_version
(
emoji_name
)
}
'>
#{
force_fallback
&&
sprite
===
false
?
emoji_image_tag
(
emoji_name
,
emoji_fallback_image_source
)
:
emoji_info
[
'moji'
]
}
</gl-emoji>"
"<gl-emoji
#{
force_fallback
&&
sprite
?
"class='emoji-icon
#{
emoji_fallback_sprite_class
}
'"
:
""
}
data-name='
#{
emoji_name
}
'
#{
image
?
"data-fallback-src='
#{
emoji_fallback_image_source
}
'"
:
""
}
#{
sprite
?
"data-fallback-sprite-class='
#{
emoji_fallback_sprite_class
}
'"
:
""
}
data-unicode-version='
#{
emoji_unicode_version
(
emoji_name
)
}
'>
#{
force_fallback
&&
sprite
===
false
?
emoji_image_tag
(
emoji_name
,
emoji_fallback_image_source
)
:
emoji_info
[
'moji'
]
}
</gl-emoji>"
end
end
end
end
end
end
lib/gitlab/gon_helper.rb
View file @
a4ed1008
...
@@ -4,6 +4,7 @@ module Gitlab
...
@@ -4,6 +4,7 @@ module Gitlab
gon
.
api_version
=
'v3'
# v4 Is not officially released yet, therefore can't be considered as "frozen"
gon
.
api_version
=
'v3'
# v4 Is not officially released yet, therefore can't be considered as "frozen"
gon
.
default_avatar_url
=
URI
.
join
(
Gitlab
.
config
.
gitlab
.
url
,
ActionController
::
Base
.
helpers
.
image_path
(
'no_avatar.png'
)).
to_s
gon
.
default_avatar_url
=
URI
.
join
(
Gitlab
.
config
.
gitlab
.
url
,
ActionController
::
Base
.
helpers
.
image_path
(
'no_avatar.png'
)).
to_s
gon
.
max_file_size
=
current_application_settings
.
max_attachment_size
gon
.
max_file_size
=
current_application_settings
.
max_attachment_size
gon
.
asset_host
=
ActionController
::
Base
.
asset_host
gon
.
relative_url_root
=
Gitlab
.
config
.
gitlab
.
relative_url_root
gon
.
relative_url_root
=
Gitlab
.
config
.
gitlab
.
relative_url_root
gon
.
shortcuts_path
=
help_page_path
(
'shortcuts'
)
gon
.
shortcuts_path
=
help_page_path
(
'shortcuts'
)
gon
.
user_color_scheme
=
Gitlab
::
ColorSchemes
.
for_user
(
current_user
).
css_class
gon
.
user_color_scheme
=
Gitlab
::
ColorSchemes
.
for_user
(
current_user
).
css_class
...
...
spec/helpers/gitlab_markdown_helper_spec.rb
View file @
a4ed1008
...
@@ -113,7 +113,7 @@ describe GitlabMarkdownHelper do
...
@@ -113,7 +113,7 @@ describe GitlabMarkdownHelper do
it
'replaces commit message with emoji to link'
do
it
'replaces commit message with emoji to link'
do
actual
=
link_to_gfm
(
':book:Book'
,
'/foo'
)
actual
=
link_to_gfm
(
':book:Book'
,
'/foo'
)
expect
(
actual
).
expect
(
actual
).
to
eq
'<gl-emoji data-name="book" data-
fallback-src="/assets/emoji/book.png" data-
unicode-version="6.0">📖</gl-emoji><a href="/foo">Book</a>'
to
eq
'<gl-emoji data-name="book" data-unicode-version="6.0">📖</gl-emoji><a href="/foo">Book</a>'
end
end
end
end
...
...
spec/lib/banzai/filter/emoji_filter_spec.rb
View file @
a4ed1008
...
@@ -88,11 +88,6 @@ describe Banzai::Filter::EmojiFilter, lib: true do
...
@@ -88,11 +88,6 @@ describe Banzai::Filter::EmojiFilter, lib: true do
expect
(
doc
.
css
(
'gl-emoji'
).
first
.
attr
(
'data-name'
)).
to
eq
'thumbsdown'
expect
(
doc
.
css
(
'gl-emoji'
).
first
.
attr
(
'data-name'
)).
to
eq
'thumbsdown'
end
end
it
'has a data-fallback-src attribute'
do
doc
=
filter
(
':-1:'
)
expect
(
doc
.
css
(
'gl-emoji'
).
first
.
attr
(
'data-fallback-src'
)).
to
end_with
'.png'
end
it
'has a data-unicode-version attribute'
do
it
'has a data-unicode-version attribute'
do
doc
=
filter
(
':-1:'
)
doc
=
filter
(
':-1:'
)
expect
(
doc
.
css
(
'gl-emoji'
).
first
.
attr
(
'data-unicode-version'
)).
to
eq
'6.0'
expect
(
doc
.
css
(
'gl-emoji'
).
first
.
attr
(
'data-unicode-version'
)).
to
eq
'6.0'
...
@@ -109,18 +104,4 @@ describe Banzai::Filter::EmojiFilter, lib: true do
...
@@ -109,18 +104,4 @@ describe Banzai::Filter::EmojiFilter, lib: true do
expect
(
doc
.
to_html
).
to
match
(
/^This deserves a <gl-emoji.+>, big time\.\z/
)
expect
(
doc
.
to_html
).
to
match
(
/^This deserves a <gl-emoji.+>, big time\.\z/
)
end
end
it
'uses a custom asset_host context'
do
ActionController
::
Base
.
asset_host
=
'https://cdn.example.com'
doc
=
filter
(
':frowning:'
,
asset_host:
'https://this-is-ignored-i-guess?'
)
expect
(
doc
.
css
(
'gl-emoji'
).
first
.
attr
(
'data-fallback-src'
)).
to
start_with
(
'https://cdn.example.com'
)
end
it
'uses a custom asset_host context'
do
ActionController
::
Base
.
asset_host
=
'https://cdn.example.com'
doc
=
filter
(
"'🎱'"
,
asset_host:
'https://this-is-ignored-i-guess?'
)
expect
(
doc
.
css
(
'gl-emoji'
).
first
.
attr
(
'data-fallback-src'
)).
to
start_with
(
'https://cdn.example.com'
)
end
end
end
spec/support/matchers/markdown_matchers.rb
View file @
a4ed1008
...
@@ -29,7 +29,8 @@ module MarkdownMatchers
...
@@ -29,7 +29,8 @@ module MarkdownMatchers
expect
(
actual
).
to
have_selector
(
'gl-emoji'
,
count:
10
)
expect
(
actual
).
to
have_selector
(
'gl-emoji'
,
count:
10
)
emoji_element
=
actual
.
at_css
(
'gl-emoji'
)
emoji_element
=
actual
.
at_css
(
'gl-emoji'
)
expect
(
emoji_element
[
'data-fallback-src'
].
to_s
).
to
start_with
(
'/assets'
)
expect
(
emoji_element
[
'data-name'
].
to_s
).
not_to
be_empty
expect
(
emoji_element
[
'data-unicode-version'
].
to_s
).
not_to
be_empty
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