Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
大大大太阳yt
driver.js
提交
ec450711
D
driver.js
项目概览
大大大太阳yt
/
driver.js
与 Fork 源项目一致
从无法访问的项目Fork
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
driver.js
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
ec450711
编写于
3月 07, 2018
作者:
K
Kamran Ahmed
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Popover auto positioning
上级
ede8cb95
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
50 addition
and
6 deletion
+50
-6
assets/scripts/src/element.js
assets/scripts/src/element.js
+47
-3
assets/styles/scss/demo.scss
assets/styles/scss/demo.scss
+0
-1
index.html
index.html
+3
-2
未找到文件。
assets/scripts/src/element.js
浏览文件 @
ec450711
...
...
@@ -75,11 +75,30 @@ export default class Element {
}
showPopover
()
{
this
.
resetPopover
();
// Position at which the element is
const
position
=
this
.
getCalculatedPosition
();
this
.
popover
.
style
.
left
=
`
${
position
.
left
}
px`
;
this
.
popover
.
style
.
top
=
`
${
position
.
bottom
+
10
}
px`
;
this
.
popover
.
style
.
display
=
'
block
'
;
const
popoverTip
=
this
.
popover
.
querySelector
(
'
.sholo-popover-tip
'
);
const
documentHeight
=
this
.
getDocumentHeight
();
const
popoverHeight
=
this
.
getPopoverHeight
();
const
popoverMargin
=
this
.
options
.
padding
+
10
;
this
.
popover
.
style
.
left
=
`
${
position
.
left
-
this
.
options
.
padding
}
px`
;
// Calculate different dimensions after attaching popover
const
documentHeightAfterPopOver
=
position
.
bottom
+
popoverHeight
+
popoverMargin
;
// If adding popover would go out of the window height, then show it to the top
if
(
documentHeightAfterPopOver
>=
documentHeight
)
{
this
.
popover
.
style
.
top
=
`
${
position
.
top
-
popoverHeight
-
popoverMargin
}
px`
;
popoverTip
.
classList
.
add
(
'
bottom
'
);
}
else
{
this
.
popover
.
style
.
top
=
`
${
position
.
bottom
+
popoverMargin
}
px`
;
popoverTip
.
classList
.
add
(
'
top
'
);
}
}
getPopover
()
{
...
...
@@ -93,4 +112,29 @@ export default class Element {
hidePopover
()
{
this
.
popover
.
style
.
display
=
'
none
'
;
}
getDocumentHeight
()
{
// eslint-disable-next-line prefer-destructuring
const
body
=
this
.
document
.
body
;
const
html
=
this
.
document
.
documentElement
;
return
Math
.
max
(
body
.
scrollHeight
,
body
.
offsetHeight
,
html
.
clientHeight
,
html
.
scrollHeight
,
html
.
offsetHeight
);
}
getPopoverHeight
()
{
return
Math
.
max
(
this
.
popover
.
scrollHeight
,
this
.
popover
.
offsetHeight
);
}
resetPopover
()
{
this
.
popover
.
style
.
display
=
'
block
'
;
this
.
popover
.
style
.
left
=
''
;
this
.
popover
.
style
.
top
=
''
;
this
.
popover
.
style
.
bottom
=
''
;
this
.
popover
.
style
.
right
=
''
;
// Remove the positional classes from tip
this
.
popover
.
querySelector
(
'
.sholo-popover-tip
'
)
.
className
=
'
sholo-popover-tip
'
;
}
}
assets/styles/scss/demo.scss
浏览文件 @
ec450711
...
...
@@ -47,7 +47,6 @@ section {
/////////////////////////////////////////
div
#sholo-popover-item
{
display
:
none
;
background
:
white
;
margin
:
0
;
...
...
index.html
浏览文件 @
ec450711
...
...
@@ -10,7 +10,7 @@
</head>
<body>
<div
id=
"sholo-popover-item"
>
<div
class=
"sholo-popover-tip
top
"
></div>
<div
class=
"sholo-popover-tip"
></div>
<div
class=
"sholo-popover-title"
>
Did you know?
</div>
<div
class=
"sholo-popover-description"
>
You can make step by step introductions with sholo!
</div>
</div>
...
...
@@ -65,9 +65,10 @@
const
sholo
=
new
Sholo
({
animate
:
true
,
opacity
:
0.8
,
padding
:
0
padding
:
5
});
document
.
querySelector
(
'
.btn__example
'
)
.
addEventListener
(
'
click
'
,
function
()
{
sholo
.
highlight
(
'
.section__header
'
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录