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
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
gitlab-ce
Commits
197f9abe
Commit
197f9abe
authored
Mar 11, 2013
by
Sato Hiroyuki
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Covert to coffee.
parent
b8f070f0
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
254 additions
and
379 deletions
+254
-379
app/assets/javascripts/branch-graph.js.coffee
app/assets/javascripts/branch-graph.js.coffee
+254
-379
No files found.
app/assets/javascripts/branch-graph.js.coffee
View file @
197f9abe
!
function
(){
class
BranchGraph
constructor
:
(
@
element
,
@
options
)
->
var
BranchGraph
=
function
(
element
,
options
){
@
preparedCommits
=
{}
this
.
element
=
element
;
@
mtime
=
0
this
.
options
=
options
;
@
mspace
=
0
@
parents
=
{}
this
.
preparedCommits
=
{};
@
colors
=
[
"#000"
]
this
.
mtime
=
0
;
@
load
()
this
.
mspace
=
0
;
this
.
parents
=
{};
load
:
->
this
.
colors
=
[
"#000"
];
$
.
ajax
url
:
@
options
.
url
this
.
load
();
method
:
"get"
};
dataType
:
"json"
success
:
$
.
proxy
((
data
)
->
BranchGraph
.
prototype
.
load
=
function
(){
$
(
".loading"
,
@
element
).
hide
()
$
.
ajax
({
@
prepareData
data
.
days
,
data
.
commits
url
:
this
.
options
.
url
,
@
buildGraph
()
method
:
'get'
,
,
this
)
dataType
:
'json'
,
success
:
$
.
proxy
(
function
(
data
){
prepareData
:
(
@
days
,
@
commits
)
->
$
(
'.loading'
,
this
.
element
).
hide
();
@
collectParents
()
this
.
prepareData
(
data
.
days
,
data
.
commits
);
@
mtime
+=
4
this
.
buildGraph
();
@
mspace
+=
10
},
this
)
});
for
c
in
@
commits
};
c
.
isParent
=
true
if
c
.
id
of
@
parents
@
preparedCommits
[
c
.
id
]
=
c
BranchGraph
.
prototype
.
prepareData
=
function
(
days
,
commits
){
this
.
days
=
days
;
@
collectColors
()
this
.
dayCount
=
days
.
length
;
this
.
commits
=
commits
;
collectParents
:
->
this
.
commitCount
=
commits
.
length
;
for
c
in
@
commits
@
mtime
=
Math
.
max
(
@
mtime
,
c
.
time
)
this
.
collectParents
();
@
mspace
=
Math
.
max
(
@
mspace
,
c
.
space
)
for
p
in
c
.
parents
this
.
mtime
+=
4
;
@
parents
[
p
[
0
]]
=
true
this
.
mspace
+=
10
;
for
(
var
i
=
0
;
i
<
this
.
commitCount
;
i
++
)
{
collectColors
:
->
if
(
this
.
commits
[
i
].
id
in
this
.
parents
)
{
k
=
0
this
.
commits
[
i
].
isParent
=
true
;
while
k
<
@
mspace
}
@
colors
.
push
Raphael
.
getColor
(.
8
)
this
.
preparedCommits
[
this
.
commits
[
i
].
id
]
=
this
.
commits
[
i
];
# Skipping a few colors in the spectrum to get more contrast between colors
}
Raphael
.
getColor
()
this
.
collectColors
();
Raphael
.
getColor
()
};
k
++
BranchGraph
.
prototype
.
collectParents
=
function
(){
buildGraph
:
->
for
(
var
i
=
0
;
i
<
this
.
commitCount
;
i
++
)
{
graphWidth
=
$
(
@
element
).
width
()
for
(
var
j
=
0
,
jj
=
this
.
commits
[
i
].
parents
.
length
;
j
<
jj
;
j
++
)
{
ch
=
@
mspace
*
20
+
100
this
.
parents
[
this
.
commits
[
i
].
parents
[
j
][
0
]]
=
true
;
cw
=
Math
.
max
(
graphWidth
,
@
mtime
*
20
+
260
)
}
r
=
Raphael
(
@
element
.
get
(
0
),
cw
,
ch
)
this
.
mtime
=
Math
.
max
(
this
.
mtime
,
this
.
commits
[
i
].
time
);
top
=
r
.
set
()
this
.
mspace
=
Math
.
max
(
this
.
mspace
,
this
.
commits
[
i
].
space
);
cuday
=
0
}
cumonth
=
""
};
offsetX
=
20
offsetY
=
60
BranchGraph
.
prototype
.
collectColors
=
function
(){
barWidth
=
Math
.
max
(
graphWidth
,
@
days
.
length
*
20
+
320
)
for
(
var
k
=
0
;
k
<
this
.
mspace
;
k
++
)
{
scrollLeft
=
cw
this
.
colors
.
push
(
Raphael
.
getColor
(.
8
));
@
raphael
=
r
//
Skipping
a
few
colors
in
the
spectrum
to
get
more
contrast
between
colors
r
.
rect
(
0
,
0
,
barWidth
,
20
).
attr
fill
:
"#222"
Raphael
.
getColor
();
Raphael
.
getColor
();
r
.
rect
(
0
,
20
,
barWidth
,
20
).
attr
fill
:
"#444"
}
};
for
day
,
mm
in
@
days
if
cuday
isnt
day
[
0
]
BranchGraph
.
prototype
.
buildGraph
=
function
(){
# Dates
var
graphWidth
=
$
(
this
.
element
).
width
()
r
.
text
(
offsetX
+
mm
*
20
,
31
,
day
[
0
])
,
ch
=
this
.
mspace
*
20
+
100
.
attr
(
,
cw
=
Math
.
max
(
graphWidth
,
this
.
mtime
*
20
+
260
)
font
:
"12px Monaco, monospace"
,
r
=
Raphael
(
this
.
element
.
get
(
0
),
cw
,
ch
)
,
top
=
r
.
set
()
,
cuday
=
0
,
cumonth
=
""
,
offsetX
=
20
,
offsetY
=
60
,
barWidth
=
Math
.
max
(
graphWidth
,
this
.
dayCount
*
20
+
320
)
,
scrollLeft
=
cw
;
this
.
raphael
=
r
;
r
.
rect
(
0
,
0
,
barWidth
,
20
).
attr
({
fill
:
"#222"
});
r
.
rect
(
0
,
20
,
barWidth
,
20
).
attr
({
fill
:
"#444"
});
for
(
mm
=
0
;
mm
<
this
.
dayCount
;
mm
++
)
{
if
(
this
.
days
[
mm
]
!=
null
){
if
(
cuday
!=
this
.
days
[
mm
][
0
]){
//
Dates
r
.
text
(
offsetX
+
mm
*
20
,
31
,
this
.
days
[
mm
][
0
]).
attr
({
font
:
"12px Monaco, monospace"
,
fill
:
"#DDD"
fill
:
"#DDD"
});
)
cuday
=
this
.
days
[
mm
][
0
];
cuday
=
day
[
0
]
}
if
(
cumonth
!=
this
.
days
[
mm
][
1
]){
if
cumonth
isnt
day
[
1
]
//
Months
# Months
r
.
text
(
offsetX
+
mm
*
20
,
11
,
this
.
days
[
mm
][
1
]).
attr
({
r
.
text
(
offsetX
+
mm
*
20
,
11
,
day
[
1
])
font
:
"12px Monaco, monospace"
,
.
attr
(
font
:
"12px Monaco, monospace"
fill
:
"#EEE"
fill
:
"#EEE"
});
)
cumonth
=
this
.
days
[
mm
][
1
];
cumonth
=
day
[
1
]
}
}
for
commit
in
@
commits
}
x
=
offsetX
+
20
*
commit
.
time
y
=
offsetY
+
10
*
commit
.
space
for
(
i
=
0
;
i
<
this
.
commitCount
;
i
++
)
{
# Draw dot
var
x
=
offsetX
+
20
*
this
.
commits
[
i
].
time
r
.
circle
(
x
,
y
,
3
).
attr
(
,
y
=
offsetY
+
10
*
this
.
commits
[
i
].
space
fill
:
@
colors
[
commit
.
space
]
,
c
,
ps
;
//
Draw
dot
r
.
circle
(
x
,
y
,
3
).
attr
({
fill
:
this
.
colors
[
this
.
commits
[
i
].
space
],
stroke
:
"none"
stroke
:
"none"
});
)
//
Draw
lines
# Draw lines
for
(
var
j
=
0
,
jj
=
this
.
commits
[
i
].
parents
.
length
;
j
<
jj
;
j
++
)
{
for
parent
in
commit
.
parents
c
=
this
.
preparedCommits
[
this
.
commits
[
i
].
parents
[
j
][
0
]];
parentCommit
=
@
preparedCommits
[
parent
[
0
]]
ps
=
this
.
commits
[
i
].
parents
[
j
][
1
];
parentX
=
offsetX
+
20
*
parentCommit
.
time
var
cx
=
offsetX
+
20
*
c
.
time
parentY1
=
offsetY
+
10
*
parentCommit
.
space
,
cy
=
offsetY
+
10
*
c
.
space
parentY2
=
offsetY
+
10
*
parent
[
1
]
,
psy
=
offsetY
+
10
*
ps
;
if
parentCommit
.
space
is
commit
.
space
and
parentCommit
.
space
is
parent
[
1
]
if
(
c
.
space
==
this
.
commits
[
i
].
space
&&
c
.
space
==
ps
)
{
r
.
path
([
"M"
,
x
,
y
,
"L"
,
parentX
,
parentY1
]).
attr
(
r
.
path
([
stroke
:
@
colors
[
parentCommit
.
space
]
"M"
,
x
,
y
,
"L"
,
cx
,
cy
]).
attr
({
stroke
:
this
.
colors
[
c
.
space
],
"stroke-width"
:
2
"stroke-width"
:
2
});
)
}
else
if
(
c
.
space
<
this
.
commits
[
i
].
space
)
{
else
if
parentCommit
.
space
<
commit
.
space
if
(
y
==
psy
)
{
if
y
is
parentY2
r
.
path
([
r
.
path
([
"M"
,
x
-
5
,
y
,
"l-5,-2,0,4,5,-2"
,
"L"
,
x
-
10
,
y
,
"L"
,
x
-
15
,
parentY2
,
"L"
,
parentX
+
5
,
parentY2
,
"L"
,
parentX
,
parentY1
]).
attr
(
"M"
,
x
-
5
,
y
,
stroke
:
@
colors
[
commit
.
space
]
"l-5,-2,0,4,5,-2"
,
"L"
,
x
-
10
,
y
,
"L"
,
x
-
15
,
psy
,
"L"
,
cx
+
5
,
psy
,
"L"
,
cx
,
cy
])
.
attr
({
stroke
:
this
.
colors
[
this
.
commits
[
i
].
space
],
"stroke-width"
:
2
});
}
else
{
r
.
path
([
"M"
,
x
-
3
,
y
-
6
,
"l-4,-3,4,-2,0,5"
,
"L"
,
x
-
5
,
y
-
10
,
"L"
,
x
-
10
,
psy
,
"L"
,
cx
+
5
,
psy
,
"L"
,
cx
,
cy
])
.
attr
({
stroke
:
this
.
colors
[
this
.
commits
[
i
].
space
],
"stroke-width"
:
2
});
}
}
else
{
r
.
path
([
"M"
,
x
-
3
,
y
+
6
,
"l-4,3,4,2,0,-5"
,
"L"
,
x
-
5
,
y
+
10
,
"L"
,
x
-
10
,
psy
,
"L"
,
cx
+
5
,
psy
,
"L"
,
cx
,
cy
])
.
attr
({
stroke
:
this
.
colors
[
c
.
space
],
"stroke-width"
:
2
"stroke-width"
:
2
});
)
}
}
if
(
this
.
commits
[
i
].
refs
)
{
else
this
.
appendLabel
(
x
,
y
,
this
.
commits
[
i
].
refs
);
r
.
path
([
"M"
,
x
-
3
,
y
-
6
,
"l-4,-3,4,-2,0,5"
,
"L"
,
x
-
5
,
y
-
10
,
"L"
,
x
-
10
,
parentY2
,
"L"
,
parentX
+
5
,
parentY2
,
"L"
,
parentX
,
parentY1
]).
attr
(
}
stroke
:
@
colors
[
commit
.
space
]
"stroke-width"
:
2
)
//
mark
commit
and
displayed
in
the
center
else
if
(
this
.
commits
[
i
].
id
==
this
.
options
.
commit_id
)
{
r
.
path
([
"M"
,
x
-
3
,
y
+
6
,
"l-4,3,4,2,0,-5"
,
"L"
,
x
-
5
,
y
+
10
,
"L"
,
x
-
10
,
parentY2
,
"L"
,
parentX
+
5
,
parentY2
,
"L"
,
parentX
,
parentY1
]).
attr
(
r
.
path
([
stroke
:
@
colors
[
parentCommit
.
space
]
'M'
,
x
,
y
-
5
,
"stroke-width"
:
2
'L'
,
x
+
4
,
y
-
15
,
)
'L'
,
x
-
4
,
y
-
15
,
'Z'
]).
attr
({
"fill"
:
"#000"
,
"fill-opacity"
:
.
7
,
"stroke"
:
"none"
});
scrollLeft
=
x
-
graphWidth
/
2
;
}
this
.
appendAnchor
(
top
,
this
.
commits
[
i
],
x
,
y
);
@
appendLabel
x
,
y
,
commit
.
refs
if
commit
.
refs
}
top
.
toFront
();
this
.
element
.
scrollLeft
(
scrollLeft
);
this
.
bindEvents
();
};
BranchGraph
.
prototype
.
bindEvents
=
function
(){
# Mark commit and displayed in the center
var
drag
=
{}
if
commit
.
id
is
@
options
.
commit_id
,
element
=
this
.
element
;
r
.
path
([
"M"
,
x
,
y
-
5
,
"L"
,
x
+
4
,
y
-
15
,
"L"
,
x
-
4
,
y
-
15
,
"Z"
]).
attr
(
fill
:
"#000"
"fill-opacity"
:
.
7
stroke
:
"none"
)
var
dragger
=
function
(
event
){
scrollLeft
=
x
-
graphWidth
/
2
element
.
scrollLeft
(
drag
.
sl
-
(
event
.
clientX
-
drag
.
x
));
element
.
scrollTop
(
drag
.
st
-
(
event
.
clientY
-
drag
.
y
));
};
element
.
on
({
@
appendAnchor
top
,
commit
,
x
,
y
mousedown
:
function
(
event
)
{
drag
=
{
x
:
event
.
clientX
,
y
:
event
.
clientY
,
st
:
element
.
scrollTop
(),
sl
:
element
.
scrollLeft
()
};
$
(
window
).
on
(
'mousemove'
,
dragger
);
}
});
$
(
window
).
on
({
mouseup
:
function
(){
//
bars
.
animate
({
opacity
:
0
},
300
);
$
(
window
).
off
(
'mousemove'
,
dragger
);
},
keydown
:
function
(
event
){
if
(
event
.
keyCode
==
37
){
//
left
element
.
scrollLeft
(
element
.
scrollLeft
()
-
50
);
}
if
(
event
.
keyCode
==
38
){
//
top
element
.
scrollTop
(
element
.
scrollTop
()
-
50
);
}
if
(
event
.
keyCode
==
39
){
//
right
element
.
scrollLeft
(
element
.
scrollLeft
()
+
50
);
}
if
(
event
.
keyCode
==
40
){
//
bottom
element
.
scrollTop
(
element
.
scrollTop
()
+
50
);
}
}
});
};
BranchGraph
.
prototype
.
appendLabel
=
function
(
x
,
y
,
refs
){
top
.
toFront
()
var
r
=
this
.
raphael
@
element
.
scrollLeft
scrollLeft
,
shortrefs
=
refs
@
bindEvents
()
,
text
,
textbox
,
rect
;
if
(
shortrefs
.
length
>
17
){
bindEvents
:
->
//
Truncate
if
longer
than
15
chars
drag
=
{}
shortrefs
=
shortrefs
.
substr
(
0
,
15
)
+
"…"
;
element
=
@
element
}
dragger
=
(
event
)
->
element
.
scrollLeft
drag
.
sl
-
(
event
.
clientX
-
drag
.
x
)
element
.
scrollTop
drag
.
st
-
(
event
.
clientY
-
drag
.
y
)
text
=
r
.
text
(
x
+
5
,
y
+
8
+
10
,
shortrefs
).
attr
({
element
.
on
mousedown
:
(
event
)
->
font
:
"10px Monaco, monospace"
,
drag
=
fill
:
"#FFF"
,
x
:
event
.
clientX
y
:
event
.
clientY
st
:
element
.
scrollTop
()
sl
:
element
.
scrollLeft
()
$
(
window
).
on
"mousemove"
,
dragger
$
(
window
).
on
mouseup
:
->
$
(
window
).
off
"mousemove"
,
dragger
keydown
:
(
event
)
->
# left
element
.
scrollLeft
element
.
scrollLeft
()
-
50
if
event
.
keyCode
is
37
# top
element
.
scrollTop
element
.
scrollTop
()
-
50
if
event
.
keyCode
is
38
# right
element
.
scrollLeft
element
.
scrollLeft
()
+
50
if
event
.
keyCode
is
39
# bottom
element
.
scrollTop
element
.
scrollTop
()
+
50
if
event
.
keyCode
is
40
appendLabel
:
(
x
,
y
,
refs
)
->
r
=
@
raphael
shortrefs
=
refs
# Truncate if longer than 15 chars
shortrefs
=
shortrefs
.
substr
(
0
,
15
)
+
"…"
if
shortrefs
.
length
>
17
text
=
r
.
text
(
x
+
5
,
y
+
8
+
10
,
shortrefs
).
attr
(
font
:
"10px Monaco, monospace"
fill
:
"#FFF"
title
:
refs
title
:
refs
});
)
textbox
=
text
.
getBBox
()
textbox
=
text
.
getBBox
();
text
.
transform
[
"t"
,
textbox
.
height
/ -4, textbox.width /
2
+
5
,
"r90"
]
text
.
transform
([
# Create rectangle based on the size of the textbox
't'
,
textbox
.
height
/-
4
,
textbox
.
width
/
2
+
5
,
rect
=
r
.
rect
(
x
,
y
,
textbox
.
width
+
15
,
textbox
.
height
+
5
,
4
).
attr
(
'r90'
fill
:
"#000"
]);
"fill-opacity"
:
.
7
stroke
:
"none"
//
Create
rectangle
based
on
the
size
of
the
textbox
)
rect
=
r
.
rect
(
x
,
y
,
textbox
.
width
+
15
,
textbox
.
height
+
5
,
4
).
attr
({
triangle
=
r
.
path
([
"M"
,
x
,
y
+
5
,
"L"
,
x
+
4
,
y
+
15
,
"L"
,
x
-
4
,
y
+
15
,
"Z"
]).
attr
(
"fill"
:
"#000"
,
fill
:
"#000"
"fill-opacity"
:
.
7
,
"fill-opacity"
:
.
7
"stroke"
:
"none"
stroke
:
"none"
});
)
# Rotate and reposition rectangle over text
triangle
=
r
.
path
([
rect
.
transform
[
"r"
,
90
,
x
,
y
,
"t"
,
15
,
-
9
]
'M'
,
x
,
y
+
5
,
# Set text to front
'L'
,
x
+
4
,
y
+
15
,
text
.
toFront
()
'L'
,
x
-
4
,
y
+
15
,
'Z'
appendAnchor
:
(
top
,
commit
,
x
,
y
)
->
]).
attr
({
r
=
@
raphael
"fill"
:
"#000"
,
options
=
@
options
"fill-opacity"
:
.
7
,
anchor
=
r
.
circle
(
x
,
y
,
10
).
attr
(
"stroke"
:
"none"
fill
:
"#000"
});
opacity
:
0
//
Rotate
and
reposition
rectangle
over
text
rect
.
transform
([
'r'
,
90
,
x
,
y
,
't'
,
15
,
-
9
]);
//
Set
text
to
front
text
.
toFront
();
};
BranchGraph
.
prototype
.
appendAnchor
=
function
(
top
,
commit
,
x
,
y
)
{
var
r
=
this
.
raphael
,
options
=
this
.
options
,
anchor
;
anchor
=
r
.
circle
(
x
,
y
,
10
).
attr
({
fill
:
"#000"
,
opacity
:
0
,
cursor
:
"pointer"
cursor
:
"pointer"
})
).
click
(
->
.
click
(
function
(){
window
.
open
options
.
commit_url
.
replace
(
"%s"
,
commit
.
id
),
"_blank"
window
.
open
(
options
.
commit_url
.
replace
(
'%s'
,
commit
.
id
),
'_blank'
);
).
hover
(
->
})
@
tooltip
=
r
.
commitTooltip
(
x
,
y
+
5
,
commit
)
.
hover
(
function
(){
top
.
push
@
tooltip
.
insertBefore
(
this
)
this
.
tooltip
=
r
.
commitTooltip
(
x
,
y
+
5
,
commit
);
,
->
top
.
push
(
this
.
tooltip
.
insertBefore
(
this
));
@
tooltip
and
@
tooltip
.
remove
()
and
delete
@
tooltip
},
function
(){
)
this
.
tooltip
&&
this
.
tooltip
.
remove
()
&&
delete
this
.
tooltip
;
top
.
push
anchor
});
top
.
push
(
anchor
);
Raphael
::
commitTooltip
=
(
x
,
y
,
commit
)
->
};
icon
=
undefined
nameText
=
undefined
this
.
BranchGraph
=
BranchGraph
;
idText
=
undefined
messageText
=
undefined
}(
this
);
boxWidth
=
300
Raphael
.
fn
.
commitTooltip
=
function
(
x
,
y
,
commit
){
boxHeight
=
200
var
icon
,
nameText
,
idText
,
messageText
icon
=
@
image
(
commit
.
author
.
icon
,
x
,
y
,
20
,
20
)
,
boxWidth
=
300
nameText
=
@
text
(
x
+
25
,
y
+
10
,
commit
.
author
.
name
)
,
boxHeight
=
200
;
idText
=
@
text
(
x
,
y
+
35
,
commit
.
id
)
messageText
=
@
text
(
x
,
y
+
50
,
commit
.
message
)
icon
=
this
.
image
(
commit
.
author
.
icon
,
x
,
y
,
20
,
20
);
textSet
=
@
set
(
icon
,
nameText
,
idText
,
messageText
).
attr
(
nameText
=
this
.
text
(
x
+
25
,
y
+
10
,
commit
.
author
.
name
);
"text-anchor"
:
"start"
idText
=
this
.
text
(
x
,
y
+
35
,
commit
.
id
);
font
:
"12px Monaco, monospace"
messageText
=
this
.
text
(
x
,
y
+
50
,
commit
.
message
);
)
nameText
.
attr
(
textSet
=
this
.
set
(
icon
,
nameText
,
idText
,
messageText
).
attr
({
font
:
"14px Arial"
"text-anchor"
:
"start"
,
"font"
:
"12px Monaco, monospace"
});
nameText
.
attr
({
"font"
:
"14px Arial"
,
"font-weight"
:
"bold"
"font-weight"
:
"bold"
});
)
idText
.
attr
({
idText
.
attr
fill
:
"#AAA"
"fill"
:
"#AAA"
@
textWrap
messageText
,
boxWidth
-
50
});
rect
=
@
rect
(
x
-
10
,
y
-
10
,
boxWidth
,
100
,
4
).
attr
(
fill
:
"#FFF"
textWrap
(
messageText
,
boxWidth
-
50
);
stroke
:
"#000"
"stroke-linecap"
:
"round"
var
rect
=
this
.
rect
(
x
-
10
,
y
-
10
,
boxWidth
,
100
,
4
).
attr
({
"fill"
:
"#FFF"
,
"stroke"
:
"#000"
,
"stroke-linecap"
:
"round"
,
"stroke-width"
:
2
"stroke-width"
:
2
});
)
var
tooltip
=
this
.
set
(
rect
,
textSet
);
tooltip
=
@
set
(
rect
,
textSet
)
rect
.
attr
(
rect
.
attr
({
height
:
tooltip
.
getBBox
().
height
+
10
"height"
:
tooltip
.
getBBox
().
height
+
10
,
width
:
tooltip
.
getBBox
().
width
+
10
"width"
:
tooltip
.
getBBox
().
width
+
10
)
});
tooltip
.
transform
[
"t"
,
20
,
20
]
tooltip
.
transform
([
tooltip
't'
,
20
,
20
]);
Raphael
::
textWrap
=
(
t
,
width
)
->
content
=
t
.
attr
(
"text"
)
return
tooltip
;
abc
=
"abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"
};
t
.
attr
text
:
abc
letterWidth
=
t
.
getBBox
().
width
/
abc
.
length
function
textWrap
(
t
,
width
)
{
t
.
attr
text
:
content
var
content
=
t
.
attr
(
"text"
);
words
=
content
.
split
(
" "
)
var
abc
=
"abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"
;
x
=
0
t
.
attr
({
s
=
[]
"text"
:
abc
});
for
word
in
words
var
letterWidth
=
t
.
getBBox
().
width
/
abc
.
length
;
if
x
+
(
word
.
length
*
letterWidth
)
>
width
s
.
push
"
\n
"
t
.
attr
({
x
=
0
"text"
:
content
x
+=
word
.
length
*
letterWidth
});
s
.
push
word
+
" "
var
words
=
content
.
split
(
" "
);
t
.
attr
text
:
s
.
join
(
""
)
var
x
=
0
,
s
=
[];
b
=
t
.
getBBox
()
for
(
var
i
=
0
;
i
<
words
.
length
;
i
++
)
{
h
=
Math
.
abs
(
b
.
y2
)
-
Math
.
abs
(
b
.
y
)
+
1
t
.
attr
y
:
b
.
y
+
h
var
l
=
words
[
i
].
length
;
if
(
x
+
(
l
*
letterWidth
)
>
width
)
{
@
BranchGraph
=
BranchGraph
s
.
push
(
"
\n
"
);
x
=
0
;
}
x
+=
l
*
letterWidth
;
s
.
push
(
words
[
i
]
+
" "
);
}
t
.
attr
({
"text"
:
s
.
join
(
""
)
});
var
b
=
t
.
getBBox
()
,
h
=
Math
.
abs
(
b
.
y2
)
-
Math
.
abs
(
b
.
y
)
+
1
;
t
.
attr
({
"y"
:
b
.
y
+
h
});
}
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