Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
C
coopwire-hypothesis
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
孙灵跃 Leon Sun
coopwire-hypothesis
Commits
c5f61c21
Commit
c5f61c21
authored
Jan 13, 2014
by
Ujvari Gergely
Committed by
Randall Leeds
Mar 28, 2014
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Jquery.ui.tooltip generates fuzzytime tooltip
parent
61c7d58f
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
421 additions
and
0 deletions
+421
-0
directives.coffee
h/js/directives.coffee
+19
-0
jquery.ui.tooltip.js
h/lib/jquery.ui.tooltip.js
+402
-0
No files found.
h/js/directives.coffee
View file @
c5f61c21
...
@@ -360,6 +360,16 @@ fuzzytime = ['$filter', '$window', ($filter, $window) ->
...
@@ -360,6 +360,16 @@ fuzzytime = ['$filter', '$window', ($filter, $window) ->
link
:
(
scope
,
elem
,
attr
,
ctrl
)
->
link
:
(
scope
,
elem
,
attr
,
ctrl
)
->
return
unless
ctrl
?
return
unless
ctrl
?
elem
.
find
(
'a'
)
.
bind
'click'
,
(
event
)
->
event
.
stopPropagation
()
.
tooltip
tooltipClass
:
'small'
position
:
collision
:
'fit'
at
:
"left center"
ctrl
.
$render
=
->
ctrl
.
$render
=
->
scope
.
ftime
=
(
$filter
'fuzzyTime'
)
ctrl
.
$viewValue
scope
.
ftime
=
(
$filter
'fuzzyTime'
)
ctrl
.
$viewValue
...
@@ -379,6 +389,15 @@ fuzzytime = ['$filter', '$window', ($filter, $window) ->
...
@@ -379,6 +389,15 @@ fuzzytime = ['$filter', '$window', ($filter, $window) ->
# For invalid timezone, use the default
# For invalid timezone, use the default
scope
.
hint
=
momentDate
.
format
(
'LLLL'
)
scope
.
hint
=
momentDate
.
format
(
'LLLL'
)
toolparams
=
tooltipClass
:
'small'
position
:
collision
:
'none'
at
:
"left center"
elem
.
tooltip
(
toolparams
)
timefunct
=
->
timefunct
=
->
$window
.
setInterval
=>
$window
.
setInterval
=>
scope
.
ftime
=
(
$filter
'fuzzyTime'
)
ctrl
.
$viewValue
scope
.
ftime
=
(
$filter
'fuzzyTime'
)
ctrl
.
$viewValue
...
...
h/lib/jquery.ui.tooltip.js
0 → 100644
View file @
c5f61c21
/*!
* jQuery UI Tooltip 1.10.3
* http://jqueryui.com
*
* Copyright 2013 jQuery Foundation and other contributors
* Released under the MIT license.
* http://jquery.org/license
*
* http://api.jqueryui.com/tooltip/
*
* Depends:
* jquery.ui.core.js
* jquery.ui.widget.js
* jquery.ui.position.js
*/
(
function
(
$
)
{
var
increments
=
0
;
function
addDescribedBy
(
elem
,
id
)
{
var
describedby
=
(
elem
.
attr
(
"aria-describedby"
)
||
""
).
split
(
/
\s
+/
);
describedby
.
push
(
id
);
elem
.
data
(
"ui-tooltip-id"
,
id
)
.
attr
(
"aria-describedby"
,
$
.
trim
(
describedby
.
join
(
" "
)
)
);
}
function
removeDescribedBy
(
elem
)
{
var
id
=
elem
.
data
(
"ui-tooltip-id"
),
describedby
=
(
elem
.
attr
(
"aria-describedby"
)
||
""
).
split
(
/
\s
+/
),
index
=
$
.
inArray
(
id
,
describedby
);
if
(
index
!==
-
1
)
{
describedby
.
splice
(
index
,
1
);
}
elem
.
removeData
(
"ui-tooltip-id"
);
describedby
=
$
.
trim
(
describedby
.
join
(
" "
)
);
if
(
describedby
)
{
elem
.
attr
(
"aria-describedby"
,
describedby
);
}
else
{
elem
.
removeAttr
(
"aria-describedby"
);
}
}
$
.
widget
(
"ui.tooltip"
,
{
version
:
"1.10.3"
,
options
:
{
content
:
function
()
{
// support: IE<9, Opera in jQuery <1.7
// .text() can't accept undefined, so coerce to a string
var
title
=
$
(
this
).
attr
(
"title"
)
||
""
;
// Escape title, since we're going from an attribute to raw HTML
return
$
(
"<a>"
).
text
(
title
).
html
();
},
hide
:
true
,
// Disabled elements have inconsistent behavior across browsers (#8661)
items
:
"[title]:not([disabled])"
,
position
:
{
my
:
"left top+15"
,
at
:
"left bottom"
,
collision
:
"flipfit flip"
},
show
:
true
,
tooltipClass
:
null
,
track
:
false
,
// callbacks
close
:
null
,
open
:
null
},
_create
:
function
()
{
this
.
_on
({
mouseover
:
"open"
,
focusin
:
"open"
});
// IDs of generated tooltips, needed for destroy
this
.
tooltips
=
{};
// IDs of parent tooltips where we removed the title attribute
this
.
parents
=
{};
if
(
this
.
options
.
disabled
)
{
this
.
_disable
();
}
},
_setOption
:
function
(
key
,
value
)
{
var
that
=
this
;
if
(
key
===
"disabled"
)
{
this
[
value
?
"_disable"
:
"_enable"
]();
this
.
options
[
key
]
=
value
;
// disable element style changes
return
;
}
this
.
_super
(
key
,
value
);
if
(
key
===
"content"
)
{
$
.
each
(
this
.
tooltips
,
function
(
id
,
element
)
{
that
.
_updateContent
(
element
);
});
}
},
_disable
:
function
()
{
var
that
=
this
;
// close open tooltips
$
.
each
(
this
.
tooltips
,
function
(
id
,
element
)
{
var
event
=
$
.
Event
(
"blur"
);
event
.
target
=
event
.
currentTarget
=
element
[
0
];
that
.
close
(
event
,
true
);
});
// remove title attributes to prevent native tooltips
this
.
element
.
find
(
this
.
options
.
items
).
addBack
().
each
(
function
()
{
var
element
=
$
(
this
);
if
(
element
.
is
(
"[title]"
)
)
{
element
.
data
(
"ui-tooltip-title"
,
element
.
attr
(
"title"
)
)
.
attr
(
"title"
,
""
);
}
});
},
_enable
:
function
()
{
// restore title attributes
this
.
element
.
find
(
this
.
options
.
items
).
addBack
().
each
(
function
()
{
var
element
=
$
(
this
);
if
(
element
.
data
(
"ui-tooltip-title"
)
)
{
element
.
attr
(
"title"
,
element
.
data
(
"ui-tooltip-title"
)
);
}
});
},
open
:
function
(
event
)
{
var
that
=
this
,
target
=
$
(
event
?
event
.
target
:
this
.
element
)
// we need closest here due to mouseover bubbling,
// but always pointing at the same event target
.
closest
(
this
.
options
.
items
);
// No element to show a tooltip for or the tooltip is already open
if
(
!
target
.
length
||
target
.
data
(
"ui-tooltip-id"
)
)
{
return
;
}
if
(
target
.
attr
(
"title"
)
)
{
target
.
data
(
"ui-tooltip-title"
,
target
.
attr
(
"title"
)
);
}
target
.
data
(
"ui-tooltip-open"
,
true
);
// kill parent tooltips, custom or native, for hover
if
(
event
&&
event
.
type
===
"mouseover"
)
{
target
.
parents
().
each
(
function
()
{
var
parent
=
$
(
this
),
blurEvent
;
if
(
parent
.
data
(
"ui-tooltip-open"
)
)
{
blurEvent
=
$
.
Event
(
"blur"
);
blurEvent
.
target
=
blurEvent
.
currentTarget
=
this
;
that
.
close
(
blurEvent
,
true
);
}
if
(
parent
.
attr
(
"title"
)
)
{
parent
.
uniqueId
();
that
.
parents
[
this
.
id
]
=
{
element
:
this
,
title
:
parent
.
attr
(
"title"
)
};
parent
.
attr
(
"title"
,
""
);
}
});
}
this
.
_updateContent
(
target
,
event
);
},
_updateContent
:
function
(
target
,
event
)
{
var
content
,
contentOption
=
this
.
options
.
content
,
that
=
this
,
eventType
=
event
?
event
.
type
:
null
;
if
(
typeof
contentOption
===
"string"
)
{
return
this
.
_open
(
event
,
target
,
contentOption
);
}
content
=
contentOption
.
call
(
target
[
0
],
function
(
response
)
{
// ignore async response if tooltip was closed already
if
(
!
target
.
data
(
"ui-tooltip-open"
)
)
{
return
;
}
// IE may instantly serve a cached response for ajax requests
// delay this call to _open so the other call to _open runs first
that
.
_delay
(
function
()
{
// jQuery creates a special event for focusin when it doesn't
// exist natively. To improve performance, the native event
// object is reused and the type is changed. Therefore, we can't
// rely on the type being correct after the event finished
// bubbling, so we set it back to the previous value. (#8740)
if
(
event
)
{
event
.
type
=
eventType
;
}
this
.
_open
(
event
,
target
,
response
);
});
});
if
(
content
)
{
this
.
_open
(
event
,
target
,
content
);
}
},
_open
:
function
(
event
,
target
,
content
)
{
var
tooltip
,
events
,
delayedShow
,
positionOption
=
$
.
extend
(
{},
this
.
options
.
position
);
if
(
!
content
)
{
return
;
}
// Content can be updated multiple times. If the tooltip already
// exists, then just update the content and bail.
tooltip
=
this
.
_find
(
target
);
if
(
tooltip
.
length
)
{
tooltip
.
find
(
".ui-tooltip-content"
).
html
(
content
);
return
;
}
// if we have a title, clear it to prevent the native tooltip
// we have to check first to avoid defining a title if none exists
// (we don't want to cause an element to start matching [title])
//
// We use removeAttr only for key events, to allow IE to export the correct
// accessible attributes. For mouse events, set to empty string to avoid
// native tooltip showing up (happens only when removing inside mouseover).
if
(
target
.
is
(
"[title]"
)
)
{
if
(
event
&&
event
.
type
===
"mouseover"
)
{
target
.
attr
(
"title"
,
""
);
}
else
{
target
.
removeAttr
(
"title"
);
}
}
tooltip
=
this
.
_tooltip
(
target
);
addDescribedBy
(
target
,
tooltip
.
attr
(
"id"
)
);
tooltip
.
find
(
".ui-tooltip-content"
).
html
(
content
);
function
position
(
event
)
{
positionOption
.
of
=
event
;
if
(
tooltip
.
is
(
":hidden"
)
)
{
return
;
}
tooltip
.
position
(
positionOption
);
}
if
(
this
.
options
.
track
&&
event
&&
/^mouse/
.
test
(
event
.
type
)
)
{
this
.
_on
(
this
.
document
,
{
mousemove
:
position
});
// trigger once to override element-relative positioning
position
(
event
);
}
else
{
tooltip
.
position
(
$
.
extend
({
of
:
target
},
this
.
options
.
position
)
);
}
tooltip
.
hide
();
this
.
_show
(
tooltip
,
this
.
options
.
show
);
// Handle tracking tooltips that are shown with a delay (#8644). As soon
// as the tooltip is visible, position the tooltip using the most recent
// event.
if
(
this
.
options
.
show
&&
this
.
options
.
show
.
delay
)
{
delayedShow
=
this
.
delayedShow
=
setInterval
(
function
()
{
if
(
tooltip
.
is
(
":visible"
)
)
{
position
(
positionOption
.
of
);
clearInterval
(
delayedShow
);
}
},
$
.
fx
.
interval
);
}
this
.
_trigger
(
"open"
,
event
,
{
tooltip
:
tooltip
}
);
events
=
{
keyup
:
function
(
event
)
{
if
(
event
.
keyCode
===
$
.
ui
.
keyCode
.
ESCAPE
)
{
var
fakeEvent
=
$
.
Event
(
event
);
fakeEvent
.
currentTarget
=
target
[
0
];
this
.
close
(
fakeEvent
,
true
);
}
},
remove
:
function
()
{
this
.
_removeTooltip
(
tooltip
);
}
};
if
(
!
event
||
event
.
type
===
"mouseover"
)
{
events
.
mouseleave
=
"close"
;
}
if
(
!
event
||
event
.
type
===
"focusin"
)
{
events
.
focusout
=
"close"
;
}
this
.
_on
(
true
,
target
,
events
);
},
close
:
function
(
event
)
{
var
that
=
this
,
target
=
$
(
event
?
event
.
currentTarget
:
this
.
element
),
tooltip
=
this
.
_find
(
target
);
// disabling closes the tooltip, so we need to track when we're closing
// to avoid an infinite loop in case the tooltip becomes disabled on close
if
(
this
.
closing
)
{
return
;
}
// Clear the interval for delayed tracking tooltips
clearInterval
(
this
.
delayedShow
);
// only set title if we had one before (see comment in _open())
if
(
target
.
data
(
"ui-tooltip-title"
)
)
{
target
.
attr
(
"title"
,
target
.
data
(
"ui-tooltip-title"
)
);
}
removeDescribedBy
(
target
);
tooltip
.
stop
(
true
);
this
.
_hide
(
tooltip
,
this
.
options
.
hide
,
function
()
{
that
.
_removeTooltip
(
$
(
this
)
);
});
target
.
removeData
(
"ui-tooltip-open"
);
this
.
_off
(
target
,
"mouseleave focusout keyup"
);
// Remove 'remove' binding only on delegated targets
if
(
target
[
0
]
!==
this
.
element
[
0
]
)
{
this
.
_off
(
target
,
"remove"
);
}
this
.
_off
(
this
.
document
,
"mousemove"
);
if
(
event
&&
event
.
type
===
"mouseleave"
)
{
$
.
each
(
this
.
parents
,
function
(
id
,
parent
)
{
$
(
parent
.
element
).
attr
(
"title"
,
parent
.
title
);
delete
that
.
parents
[
id
];
});
}
this
.
closing
=
true
;
this
.
_trigger
(
"close"
,
event
,
{
tooltip
:
tooltip
}
);
this
.
closing
=
false
;
},
_tooltip
:
function
(
element
)
{
var
id
=
"ui-tooltip-"
+
increments
++
,
tooltip
=
$
(
"<div>"
)
.
attr
({
id
:
id
,
role
:
"tooltip"
})
.
addClass
(
"ui-tooltip ui-widget ui-corner-all ui-widget-content "
+
(
this
.
options
.
tooltipClass
||
""
)
);
$
(
"<div>"
)
.
addClass
(
"ui-tooltip-content"
)
.
appendTo
(
tooltip
);
tooltip
.
appendTo
(
this
.
document
[
0
].
body
);
this
.
tooltips
[
id
]
=
element
;
return
tooltip
;
},
_find
:
function
(
target
)
{
var
id
=
target
.
data
(
"ui-tooltip-id"
);
return
id
?
$
(
"#"
+
id
)
:
$
();
},
_removeTooltip
:
function
(
tooltip
)
{
tooltip
.
remove
();
delete
this
.
tooltips
[
tooltip
.
attr
(
"id"
)
];
},
_destroy
:
function
()
{
var
that
=
this
;
// close open tooltips
$
.
each
(
this
.
tooltips
,
function
(
id
,
element
)
{
// Delegate to close method to handle common cleanup
var
event
=
$
.
Event
(
"blur"
);
event
.
target
=
event
.
currentTarget
=
element
[
0
];
that
.
close
(
event
,
true
);
// Remove immediately; destroying an open tooltip doesn't use the
// hide animation
$
(
"#"
+
id
).
remove
();
// Restore the title
if
(
element
.
data
(
"ui-tooltip-title"
)
)
{
element
.
attr
(
"title"
,
element
.
data
(
"ui-tooltip-title"
)
);
element
.
removeData
(
"ui-tooltip-title"
);
}
});
}
});
}(
jQuery
)
);
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