Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
E
edx-platform
Overview
Overview
Details
Activity
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
edx
edx-platform
Commits
ad45a44a
Commit
ad45a44a
authored
Aug 17, 2012
by
Tom Giannattasio
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
added bootstrap js and other dependencies; tweaked settings template
parent
b0b10aa5
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
97 additions
and
6 deletions
+97
-6
lms/static/js/bootstrap.min.js
+7
-0
lms/static/sass/course/wiki/_wiki.scss
+16
-5
lms/templates/wiki/base.html
+22
-1
lms/templates/wiki/settings.html
+52
-0
No files found.
lms/static/js/bootstrap.min.js
0 → 100644
View file @
ad45a44a
/*!
* Bootstrap.js by @fat & @mdo
* Copyright 2012 Twitter, Inc.
* http://www.apache.org/licenses/LICENSE-2.0.txt
*/
!
function
(
a
){
a
(
function
(){
"use strict"
,
a
.
support
.
transition
=
function
(){
var
a
=
function
(){
var
a
=
document
.
createElement
(
"bootstrap"
),
b
=
{
WebkitTransition
:
"webkitTransitionEnd"
,
MozTransition
:
"transitionend"
,
OTransition
:
"oTransitionEnd"
,
msTransition
:
"MSTransitionEnd"
,
transition
:
"transitionend"
},
c
;
for
(
c
in
b
)
if
(
a
.
style
[
c
]
!==
undefined
)
return
b
[
c
]}();
return
a
&&
{
end
:
a
}}()})}(
window
.
jQuery
),
!
function
(
a
){
"use strict"
;
var
b
=
'[data-dismiss="alert"]'
,
c
=
function
(
c
){
a
(
c
).
on
(
"click"
,
b
,
this
.
close
)};
c
.
prototype
.
close
=
function
(
b
){
function
f
(){
e
.
trigger
(
"closed"
).
remove
()}
var
c
=
a
(
this
),
d
=
c
.
attr
(
"data-target"
),
e
;
d
||
(
d
=
c
.
attr
(
"href"
),
d
=
d
&&
d
.
replace
(
/.*
(?=
#
[^\s]
*$
)
/
,
""
)),
e
=
a
(
d
),
b
&&
b
.
preventDefault
(),
e
.
length
||
(
e
=
c
.
hasClass
(
"alert"
)?
c
:
c
.
parent
()),
e
.
trigger
(
b
=
a
.
Event
(
"close"
));
if
(
b
.
isDefaultPrevented
())
return
;
e
.
removeClass
(
"in"
),
a
.
support
.
transition
&&
e
.
hasClass
(
"fade"
)?
e
.
on
(
a
.
support
.
transition
.
end
,
f
):
f
()},
a
.
fn
.
alert
=
function
(
b
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"alert"
);
e
||
d
.
data
(
"alert"
,
e
=
new
c
(
this
)),
typeof
b
==
"string"
&&
e
[
b
].
call
(
d
)})},
a
.
fn
.
alert
.
Constructor
=
c
,
a
(
function
(){
a
(
"body"
).
on
(
"click.alert.data-api"
,
b
,
c
.
prototype
.
close
)})}(
window
.
jQuery
),
!
function
(
a
){
"use strict"
;
var
b
=
function
(
b
,
c
){
this
.
$element
=
a
(
b
),
this
.
options
=
a
.
extend
({},
a
.
fn
.
button
.
defaults
,
c
)};
b
.
prototype
.
setState
=
function
(
a
){
var
b
=
"disabled"
,
c
=
this
.
$element
,
d
=
c
.
data
(),
e
=
c
.
is
(
"input"
)?
"val"
:
"html"
;
a
+=
"Text"
,
d
.
resetText
||
c
.
data
(
"resetText"
,
c
[
e
]()),
c
[
e
](
d
[
a
]
||
this
.
options
[
a
]),
setTimeout
(
function
(){
a
==
"loadingText"
?
c
.
addClass
(
b
).
attr
(
b
,
b
):
c
.
removeClass
(
b
).
removeAttr
(
b
)},
0
)},
b
.
prototype
.
toggle
=
function
(){
var
a
=
this
.
$element
.
parent
(
'[data-toggle="buttons-radio"]'
);
a
&&
a
.
find
(
".active"
).
removeClass
(
"active"
),
this
.
$element
.
toggleClass
(
"active"
)},
a
.
fn
.
button
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"button"
),
f
=
typeof
c
==
"object"
&&
c
;
e
||
d
.
data
(
"button"
,
e
=
new
b
(
this
,
f
)),
c
==
"toggle"
?
e
.
toggle
():
c
&&
e
.
setState
(
c
)})},
a
.
fn
.
button
.
defaults
=
{
loadingText
:
"loading..."
},
a
.
fn
.
button
.
Constructor
=
b
,
a
(
function
(){
a
(
"body"
).
on
(
"click.button.data-api"
,
"[data-toggle^=button]"
,
function
(
b
){
var
c
=
a
(
b
.
target
);
c
.
hasClass
(
"btn"
)
||
(
c
=
c
.
closest
(
".btn"
)),
c
.
button
(
"toggle"
)})})}(
window
.
jQuery
),
!
function
(
a
){
"use strict"
;
var
b
=
function
(
b
,
c
){
this
.
$element
=
a
(
b
),
this
.
options
=
c
,
this
.
options
.
slide
&&
this
.
slide
(
this
.
options
.
slide
),
this
.
options
.
pause
==
"hover"
&&
this
.
$element
.
on
(
"mouseenter"
,
a
.
proxy
(
this
.
pause
,
this
)).
on
(
"mouseleave"
,
a
.
proxy
(
this
.
cycle
,
this
))};
b
.
prototype
=
{
cycle
:
function
(
b
){
return
b
||
(
this
.
paused
=!
1
),
this
.
options
.
interval
&&!
this
.
paused
&&
(
this
.
interval
=
setInterval
(
a
.
proxy
(
this
.
next
,
this
),
this
.
options
.
interval
)),
this
},
to
:
function
(
b
){
var
c
=
this
.
$element
.
find
(
".active"
),
d
=
c
.
parent
().
children
(),
e
=
d
.
index
(
c
),
f
=
this
;
if
(
b
>
d
.
length
-
1
||
b
<
0
)
return
;
return
this
.
sliding
?
this
.
$element
.
one
(
"slid"
,
function
(){
f
.
to
(
b
)}):
e
==
b
?
this
.
pause
().
cycle
():
this
.
slide
(
b
>
e
?
"next"
:
"prev"
,
a
(
d
[
b
]))},
pause
:
function
(
a
){
return
a
||
(
this
.
paused
=!
0
),
clearInterval
(
this
.
interval
),
this
.
interval
=
null
,
this
},
next
:
function
(){
if
(
this
.
sliding
)
return
;
return
this
.
slide
(
"next"
)},
prev
:
function
(){
if
(
this
.
sliding
)
return
;
return
this
.
slide
(
"prev"
)},
slide
:
function
(
b
,
c
){
var
d
=
this
.
$element
.
find
(
".active"
),
e
=
c
||
d
[
b
](),
f
=
this
.
interval
,
g
=
b
==
"next"
?
"left"
:
"right"
,
h
=
b
==
"next"
?
"first"
:
"last"
,
i
=
this
,
j
=
a
.
Event
(
"slide"
);
this
.
sliding
=!
0
,
f
&&
this
.
pause
(),
e
=
e
.
length
?
e
:
this
.
$element
.
find
(
".item"
)[
h
]();
if
(
e
.
hasClass
(
"active"
))
return
;
if
(
a
.
support
.
transition
&&
this
.
$element
.
hasClass
(
"slide"
)){
this
.
$element
.
trigger
(
j
);
if
(
j
.
isDefaultPrevented
())
return
;
e
.
addClass
(
b
),
e
[
0
].
offsetWidth
,
d
.
addClass
(
g
),
e
.
addClass
(
g
),
this
.
$element
.
one
(
a
.
support
.
transition
.
end
,
function
(){
e
.
removeClass
([
b
,
g
].
join
(
" "
)).
addClass
(
"active"
),
d
.
removeClass
([
"active"
,
g
].
join
(
" "
)),
i
.
sliding
=!
1
,
setTimeout
(
function
(){
i
.
$element
.
trigger
(
"slid"
)},
0
)})}
else
{
this
.
$element
.
trigger
(
j
);
if
(
j
.
isDefaultPrevented
())
return
;
d
.
removeClass
(
"active"
),
e
.
addClass
(
"active"
),
this
.
sliding
=!
1
,
this
.
$element
.
trigger
(
"slid"
)}
return
f
&&
this
.
cycle
(),
this
}},
a
.
fn
.
carousel
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"carousel"
),
f
=
a
.
extend
({},
a
.
fn
.
carousel
.
defaults
,
typeof
c
==
"object"
&&
c
);
e
||
d
.
data
(
"carousel"
,
e
=
new
b
(
this
,
f
)),
typeof
c
==
"number"
?
e
.
to
(
c
):
typeof
c
==
"string"
||
(
c
=
f
.
slide
)?
e
[
c
]():
f
.
interval
&&
e
.
cycle
()})},
a
.
fn
.
carousel
.
defaults
=
{
interval
:
5
e3
,
pause
:
"hover"
},
a
.
fn
.
carousel
.
Constructor
=
b
,
a
(
function
(){
a
(
"body"
).
on
(
"click.carousel.data-api"
,
"[data-slide]"
,
function
(
b
){
var
c
=
a
(
this
),
d
,
e
=
a
(
c
.
attr
(
"data-target"
)
||
(
d
=
c
.
attr
(
"href"
))
&&
d
.
replace
(
/.*
(?=
#
[^\s]
+$
)
/
,
""
)),
f
=!
e
.
data
(
"modal"
)
&&
a
.
extend
({},
e
.
data
(),
c
.
data
());
e
.
carousel
(
f
),
b
.
preventDefault
()})})}(
window
.
jQuery
),
!
function
(
a
){
"use strict"
;
var
b
=
function
(
b
,
c
){
this
.
$element
=
a
(
b
),
this
.
options
=
a
.
extend
({},
a
.
fn
.
collapse
.
defaults
,
c
),
this
.
options
.
parent
&&
(
this
.
$parent
=
a
(
this
.
options
.
parent
)),
this
.
options
.
toggle
&&
this
.
toggle
()};
b
.
prototype
=
{
constructor
:
b
,
dimension
:
function
(){
var
a
=
this
.
$element
.
hasClass
(
"width"
);
return
a
?
"width"
:
"height"
},
show
:
function
(){
var
b
,
c
,
d
,
e
;
if
(
this
.
transitioning
)
return
;
b
=
this
.
dimension
(),
c
=
a
.
camelCase
([
"scroll"
,
b
].
join
(
"-"
)),
d
=
this
.
$parent
&&
this
.
$parent
.
find
(
"> .accordion-group > .in"
);
if
(
d
&&
d
.
length
){
e
=
d
.
data
(
"collapse"
);
if
(
e
&&
e
.
transitioning
)
return
;
d
.
collapse
(
"hide"
),
e
||
d
.
data
(
"collapse"
,
null
)}
this
.
$element
[
b
](
0
),
this
.
transition
(
"addClass"
,
a
.
Event
(
"show"
),
"shown"
),
this
.
$element
[
b
](
this
.
$element
[
0
][
c
])},
hide
:
function
(){
var
b
;
if
(
this
.
transitioning
)
return
;
b
=
this
.
dimension
(),
this
.
reset
(
this
.
$element
[
b
]()),
this
.
transition
(
"removeClass"
,
a
.
Event
(
"hide"
),
"hidden"
),
this
.
$element
[
b
](
0
)},
reset
:
function
(
a
){
var
b
=
this
.
dimension
();
return
this
.
$element
.
removeClass
(
"collapse"
)[
b
](
a
||
"auto"
)[
0
].
offsetWidth
,
this
.
$element
[
a
!==
null
?
"addClass"
:
"removeClass"
](
"collapse"
),
this
},
transition
:
function
(
b
,
c
,
d
){
var
e
=
this
,
f
=
function
(){
c
.
type
==
"show"
&&
e
.
reset
(),
e
.
transitioning
=
0
,
e
.
$element
.
trigger
(
d
)};
this
.
$element
.
trigger
(
c
);
if
(
c
.
isDefaultPrevented
())
return
;
this
.
transitioning
=
1
,
this
.
$element
[
b
](
"in"
),
a
.
support
.
transition
&&
this
.
$element
.
hasClass
(
"collapse"
)?
this
.
$element
.
one
(
a
.
support
.
transition
.
end
,
f
):
f
()},
toggle
:
function
(){
this
[
this
.
$element
.
hasClass
(
"in"
)?
"hide"
:
"show"
]()}},
a
.
fn
.
collapse
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"collapse"
),
f
=
typeof
c
==
"object"
&&
c
;
e
||
d
.
data
(
"collapse"
,
e
=
new
b
(
this
,
f
)),
typeof
c
==
"string"
&&
e
[
c
]()})},
a
.
fn
.
collapse
.
defaults
=
{
toggle
:
!
0
},
a
.
fn
.
collapse
.
Constructor
=
b
,
a
(
function
(){
a
(
"body"
).
on
(
"click.collapse.data-api"
,
"[data-toggle=collapse]"
,
function
(
b
){
var
c
=
a
(
this
),
d
,
e
=
c
.
attr
(
"data-target"
)
||
b
.
preventDefault
()
||
(
d
=
c
.
attr
(
"href"
))
&&
d
.
replace
(
/.*
(?=
#
[^\s]
+$
)
/
,
""
),
f
=
a
(
e
).
data
(
"collapse"
)?
"toggle"
:
c
.
data
();
a
(
e
).
collapse
(
f
)})})}(
window
.
jQuery
),
!
function
(
a
){
function
d
(){
a
(
b
).
parent
().
removeClass
(
"open"
)}
"use strict"
;
var
b
=
'[data-toggle="dropdown"]'
,
c
=
function
(
b
){
var
c
=
a
(
b
).
on
(
"click.dropdown.data-api"
,
this
.
toggle
);
a
(
"html"
).
on
(
"click.dropdown.data-api"
,
function
(){
c
.
parent
().
removeClass
(
"open"
)})};
c
.
prototype
=
{
constructor
:
c
,
toggle
:
function
(
b
){
var
c
=
a
(
this
),
e
,
f
,
g
;
if
(
c
.
is
(
".disabled, :disabled"
))
return
;
return
f
=
c
.
attr
(
"data-target"
),
f
||
(
f
=
c
.
attr
(
"href"
),
f
=
f
&&
f
.
replace
(
/.*
(?=
#
[^\s]
*$
)
/
,
""
)),
e
=
a
(
f
),
e
.
length
||
(
e
=
c
.
parent
()),
g
=
e
.
hasClass
(
"open"
),
d
(),
g
||
e
.
toggleClass
(
"open"
),
!
1
}},
a
.
fn
.
dropdown
=
function
(
b
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"dropdown"
);
e
||
d
.
data
(
"dropdown"
,
e
=
new
c
(
this
)),
typeof
b
==
"string"
&&
e
[
b
].
call
(
d
)})},
a
.
fn
.
dropdown
.
Constructor
=
c
,
a
(
function
(){
a
(
"html"
).
on
(
"click.dropdown.data-api"
,
d
),
a
(
"body"
).
on
(
"click.dropdown"
,
".dropdown form"
,
function
(
a
){
a
.
stopPropagation
()}).
on
(
"click.dropdown.data-api"
,
b
,
c
.
prototype
.
toggle
)})}(
window
.
jQuery
),
!
function
(
a
){
function
c
(){
var
b
=
this
,
c
=
setTimeout
(
function
(){
b
.
$element
.
off
(
a
.
support
.
transition
.
end
),
d
.
call
(
b
)},
500
);
this
.
$element
.
one
(
a
.
support
.
transition
.
end
,
function
(){
clearTimeout
(
c
),
d
.
call
(
b
)})}
function
d
(
a
){
this
.
$element
.
hide
().
trigger
(
"hidden"
),
e
.
call
(
this
)}
function
e
(
b
){
var
c
=
this
,
d
=
this
.
$element
.
hasClass
(
"fade"
)?
"fade"
:
""
;
if
(
this
.
isShown
&&
this
.
options
.
backdrop
){
var
e
=
a
.
support
.
transition
&&
d
;
this
.
$backdrop
=
a
(
'<div class="modal-backdrop '
+
d
+
'" />'
).
appendTo
(
document
.
body
),
this
.
options
.
backdrop
!=
"static"
&&
this
.
$backdrop
.
click
(
a
.
proxy
(
this
.
hide
,
this
)),
e
&&
this
.
$backdrop
[
0
].
offsetWidth
,
this
.
$backdrop
.
addClass
(
"in"
),
e
?
this
.
$backdrop
.
one
(
a
.
support
.
transition
.
end
,
b
):
b
()}
else
!
this
.
isShown
&&
this
.
$backdrop
?(
this
.
$backdrop
.
removeClass
(
"in"
),
a
.
support
.
transition
&&
this
.
$element
.
hasClass
(
"fade"
)?
this
.
$backdrop
.
one
(
a
.
support
.
transition
.
end
,
a
.
proxy
(
f
,
this
)):
f
.
call
(
this
)):
b
&&
b
()}
function
f
(){
this
.
$backdrop
.
remove
(),
this
.
$backdrop
=
null
}
function
g
(){
var
b
=
this
;
this
.
isShown
&&
this
.
options
.
keyboard
?
a
(
document
).
on
(
"keyup.dismiss.modal"
,
function
(
a
){
a
.
which
==
27
&&
b
.
hide
()}):
this
.
isShown
||
a
(
document
).
off
(
"keyup.dismiss.modal"
)}
"use strict"
;
var
b
=
function
(
b
,
c
){
this
.
options
=
c
,
this
.
$element
=
a
(
b
).
delegate
(
'[data-dismiss="modal"]'
,
"click.dismiss.modal"
,
a
.
proxy
(
this
.
hide
,
this
))};
b
.
prototype
=
{
constructor
:
b
,
toggle
:
function
(){
return
this
[
this
.
isShown
?
"hide"
:
"show"
]()},
show
:
function
(){
var
b
=
this
,
c
=
a
.
Event
(
"show"
);
this
.
$element
.
trigger
(
c
);
if
(
this
.
isShown
||
c
.
isDefaultPrevented
())
return
;
a
(
"body"
).
addClass
(
"modal-open"
),
this
.
isShown
=!
0
,
g
.
call
(
this
),
e
.
call
(
this
,
function
(){
var
c
=
a
.
support
.
transition
&&
b
.
$element
.
hasClass
(
"fade"
);
b
.
$element
.
parent
().
length
||
b
.
$element
.
appendTo
(
document
.
body
),
b
.
$element
.
show
(),
c
&&
b
.
$element
[
0
].
offsetWidth
,
b
.
$element
.
addClass
(
"in"
),
c
?
b
.
$element
.
one
(
a
.
support
.
transition
.
end
,
function
(){
b
.
$element
.
trigger
(
"shown"
)}):
b
.
$element
.
trigger
(
"shown"
)})},
hide
:
function
(
b
){
b
&&
b
.
preventDefault
();
var
e
=
this
;
b
=
a
.
Event
(
"hide"
),
this
.
$element
.
trigger
(
b
);
if
(
!
this
.
isShown
||
b
.
isDefaultPrevented
())
return
;
this
.
isShown
=!
1
,
a
(
"body"
).
removeClass
(
"modal-open"
),
g
.
call
(
this
),
this
.
$element
.
removeClass
(
"in"
),
a
.
support
.
transition
&&
this
.
$element
.
hasClass
(
"fade"
)?
c
.
call
(
this
):
d
.
call
(
this
)}},
a
.
fn
.
modal
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"modal"
),
f
=
a
.
extend
({},
a
.
fn
.
modal
.
defaults
,
d
.
data
(),
typeof
c
==
"object"
&&
c
);
e
||
d
.
data
(
"modal"
,
e
=
new
b
(
this
,
f
)),
typeof
c
==
"string"
?
e
[
c
]():
f
.
show
&&
e
.
show
()})},
a
.
fn
.
modal
.
defaults
=
{
backdrop
:
!
0
,
keyboard
:
!
0
,
show
:
!
0
},
a
.
fn
.
modal
.
Constructor
=
b
,
a
(
function
(){
a
(
"body"
).
on
(
"click.modal.data-api"
,
'[data-toggle="modal"]'
,
function
(
b
){
var
c
=
a
(
this
),
d
,
e
=
a
(
c
.
attr
(
"data-target"
)
||
(
d
=
c
.
attr
(
"href"
))
&&
d
.
replace
(
/.*
(?=
#
[^\s]
+$
)
/
,
""
)),
f
=
e
.
data
(
"modal"
)?
"toggle"
:
a
.
extend
({},
e
.
data
(),
c
.
data
());
b
.
preventDefault
(),
e
.
modal
(
f
)})})}(
window
.
jQuery
),
!
function
(
a
){
"use strict"
;
var
b
=
function
(
a
,
b
){
this
.
init
(
"tooltip"
,
a
,
b
)};
b
.
prototype
=
{
constructor
:
b
,
init
:
function
(
b
,
c
,
d
){
var
e
,
f
;
this
.
type
=
b
,
this
.
$element
=
a
(
c
),
this
.
options
=
this
.
getOptions
(
d
),
this
.
enabled
=!
0
,
this
.
options
.
trigger
!=
"manual"
&&
(
e
=
this
.
options
.
trigger
==
"hover"
?
"mouseenter"
:
"focus"
,
f
=
this
.
options
.
trigger
==
"hover"
?
"mouseleave"
:
"blur"
,
this
.
$element
.
on
(
e
,
this
.
options
.
selector
,
a
.
proxy
(
this
.
enter
,
this
)),
this
.
$element
.
on
(
f
,
this
.
options
.
selector
,
a
.
proxy
(
this
.
leave
,
this
))),
this
.
options
.
selector
?
this
.
_options
=
a
.
extend
({},
this
.
options
,{
trigger
:
"manual"
,
selector
:
""
}):
this
.
fixTitle
()},
getOptions
:
function
(
b
){
return
b
=
a
.
extend
({},
a
.
fn
[
this
.
type
].
defaults
,
b
,
this
.
$element
.
data
()),
b
.
delay
&&
typeof
b
.
delay
==
"number"
&&
(
b
.
delay
=
{
show
:
b
.
delay
,
hide
:
b
.
delay
}),
b
},
enter
:
function
(
b
){
var
c
=
a
(
b
.
currentTarget
)[
this
.
type
](
this
.
_options
).
data
(
this
.
type
);
if
(
!
c
.
options
.
delay
||!
c
.
options
.
delay
.
show
)
return
c
.
show
();
clearTimeout
(
this
.
timeout
),
c
.
hoverState
=
"in"
,
this
.
timeout
=
setTimeout
(
function
(){
c
.
hoverState
==
"in"
&&
c
.
show
()},
c
.
options
.
delay
.
show
)},
leave
:
function
(
b
){
var
c
=
a
(
b
.
currentTarget
)[
this
.
type
](
this
.
_options
).
data
(
this
.
type
);
this
.
timeout
&&
clearTimeout
(
this
.
timeout
);
if
(
!
c
.
options
.
delay
||!
c
.
options
.
delay
.
hide
)
return
c
.
hide
();
c
.
hoverState
=
"out"
,
this
.
timeout
=
setTimeout
(
function
(){
c
.
hoverState
==
"out"
&&
c
.
hide
()},
c
.
options
.
delay
.
hide
)},
show
:
function
(){
var
a
,
b
,
c
,
d
,
e
,
f
,
g
;
if
(
this
.
hasContent
()
&&
this
.
enabled
){
a
=
this
.
tip
(),
this
.
setContent
(),
this
.
options
.
animation
&&
a
.
addClass
(
"fade"
),
f
=
typeof
this
.
options
.
placement
==
"function"
?
this
.
options
.
placement
.
call
(
this
,
a
[
0
],
this
.
$element
[
0
]):
this
.
options
.
placement
,
b
=
/in/
.
test
(
f
),
a
.
remove
().
css
({
top
:
0
,
left
:
0
,
display
:
"block"
}).
appendTo
(
b
?
this
.
$element
:
document
.
body
),
c
=
this
.
getPosition
(
b
),
d
=
a
[
0
].
offsetWidth
,
e
=
a
[
0
].
offsetHeight
;
switch
(
b
?
f
.
split
(
" "
)[
1
]:
f
){
case
"bottom"
:
g
=
{
top
:
c
.
top
+
c
.
height
,
left
:
c
.
left
+
c
.
width
/
2
-
d
/
2
};
break
;
case
"top"
:
g
=
{
top
:
c
.
top
-
e
,
left
:
c
.
left
+
c
.
width
/
2
-
d
/
2
};
break
;
case
"left"
:
g
=
{
top
:
c
.
top
+
c
.
height
/
2
-
e
/
2
,
left
:
c
.
left
-
d
};
break
;
case
"right"
:
g
=
{
top
:
c
.
top
+
c
.
height
/
2
-
e
/
2
,
left
:
c
.
left
+
c
.
width
}}
a
.
css
(
g
).
addClass
(
f
).
addClass
(
"in"
)}},
isHTML
:
function
(
a
){
return
typeof
a
!=
"string"
||
a
.
charAt
(
0
)
===
"<"
&&
a
.
charAt
(
a
.
length
-
1
)
===
">"
&&
a
.
length
>=
3
||
/^
(?:[^
<
]
*<
[\w\W]
+>
[^
>
]
*$
)
/
.
exec
(
a
)},
setContent
:
function
(){
var
a
=
this
.
tip
(),
b
=
this
.
getTitle
();
a
.
find
(
".tooltip-inner"
)[
this
.
isHTML
(
b
)?
"html"
:
"text"
](
b
),
a
.
removeClass
(
"fade in top bottom left right"
)},
hide
:
function
(){
function
d
(){
var
b
=
setTimeout
(
function
(){
c
.
off
(
a
.
support
.
transition
.
end
).
remove
()},
500
);
c
.
one
(
a
.
support
.
transition
.
end
,
function
(){
clearTimeout
(
b
),
c
.
remove
()})}
var
b
=
this
,
c
=
this
.
tip
();
c
.
removeClass
(
"in"
),
a
.
support
.
transition
&&
this
.
$tip
.
hasClass
(
"fade"
)?
d
():
c
.
remove
()},
fixTitle
:
function
(){
var
a
=
this
.
$element
;(
a
.
attr
(
"title"
)
||
typeof
a
.
attr
(
"data-original-title"
)
!=
"string"
)
&&
a
.
attr
(
"data-original-title"
,
a
.
attr
(
"title"
)
||
""
).
removeAttr
(
"title"
)},
hasContent
:
function
(){
return
this
.
getTitle
()},
getPosition
:
function
(
b
){
return
a
.
extend
({},
b
?{
top
:
0
,
left
:
0
}:
this
.
$element
.
offset
(),{
width
:
this
.
$element
[
0
].
offsetWidth
,
height
:
this
.
$element
[
0
].
offsetHeight
})},
getTitle
:
function
(){
var
a
,
b
=
this
.
$element
,
c
=
this
.
options
;
return
a
=
b
.
attr
(
"data-original-title"
)
||
(
typeof
c
.
title
==
"function"
?
c
.
title
.
call
(
b
[
0
]):
c
.
title
),
a
},
tip
:
function
(){
return
this
.
$tip
=
this
.
$tip
||
a
(
this
.
options
.
template
)},
validate
:
function
(){
this
.
$element
[
0
].
parentNode
||
(
this
.
hide
(),
this
.
$element
=
null
,
this
.
options
=
null
)},
enable
:
function
(){
this
.
enabled
=!
0
},
disable
:
function
(){
this
.
enabled
=!
1
},
toggleEnabled
:
function
(){
this
.
enabled
=!
this
.
enabled
},
toggle
:
function
(){
this
[
this
.
tip
().
hasClass
(
"in"
)?
"hide"
:
"show"
]()}},
a
.
fn
.
tooltip
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"tooltip"
),
f
=
typeof
c
==
"object"
&&
c
;
e
||
d
.
data
(
"tooltip"
,
e
=
new
b
(
this
,
f
)),
typeof
c
==
"string"
&&
e
[
c
]()})},
a
.
fn
.
tooltip
.
Constructor
=
b
,
a
.
fn
.
tooltip
.
defaults
=
{
animation
:
!
0
,
placement
:
"top"
,
selector
:
!
1
,
template
:
'<div class="tooltip"><div class="tooltip-arrow"></div><div class="tooltip-inner"></div></div>'
,
trigger
:
"hover"
,
title
:
""
,
delay
:
0
}}(
window
.
jQuery
),
!
function
(
a
){
"use strict"
;
var
b
=
function
(
a
,
b
){
this
.
init
(
"popover"
,
a
,
b
)};
b
.
prototype
=
a
.
extend
({},
a
.
fn
.
tooltip
.
Constructor
.
prototype
,{
constructor
:
b
,
setContent
:
function
(){
var
a
=
this
.
tip
(),
b
=
this
.
getTitle
(),
c
=
this
.
getContent
();
a
.
find
(
".popover-title"
)[
this
.
isHTML
(
b
)?
"html"
:
"text"
](
b
),
a
.
find
(
".popover-content > *"
)[
this
.
isHTML
(
c
)?
"html"
:
"text"
](
c
),
a
.
removeClass
(
"fade top bottom left right in"
)},
hasContent
:
function
(){
return
this
.
getTitle
()
||
this
.
getContent
()},
getContent
:
function
(){
var
a
,
b
=
this
.
$element
,
c
=
this
.
options
;
return
a
=
b
.
attr
(
"data-content"
)
||
(
typeof
c
.
content
==
"function"
?
c
.
content
.
call
(
b
[
0
]):
c
.
content
),
a
},
tip
:
function
(){
return
this
.
$tip
||
(
this
.
$tip
=
a
(
this
.
options
.
template
)),
this
.
$tip
}}),
a
.
fn
.
popover
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"popover"
),
f
=
typeof
c
==
"object"
&&
c
;
e
||
d
.
data
(
"popover"
,
e
=
new
b
(
this
,
f
)),
typeof
c
==
"string"
&&
e
[
c
]()})},
a
.
fn
.
popover
.
Constructor
=
b
,
a
.
fn
.
popover
.
defaults
=
a
.
extend
({},
a
.
fn
.
tooltip
.
defaults
,{
placement
:
"right"
,
content
:
""
,
template
:
'<div class="popover"><div class="arrow"></div><div class="popover-inner"><h3 class="popover-title"></h3><div class="popover-content"><p></p></div></div></div>'
})}(
window
.
jQuery
),
!
function
(
a
){
function
b
(
b
,
c
){
var
d
=
a
.
proxy
(
this
.
process
,
this
),
e
=
a
(
b
).
is
(
"body"
)?
a
(
window
):
a
(
b
),
f
;
this
.
options
=
a
.
extend
({},
a
.
fn
.
scrollspy
.
defaults
,
c
),
this
.
$scrollElement
=
e
.
on
(
"scroll.scroll.data-api"
,
d
),
this
.
selector
=
(
this
.
options
.
target
||
(
f
=
a
(
b
).
attr
(
"href"
))
&&
f
.
replace
(
/.*
(?=
#
[^\s]
+$
)
/
,
""
)
||
""
)
+
" .nav li > a"
,
this
.
$body
=
a
(
"body"
),
this
.
refresh
(),
this
.
process
()}
"use strict"
,
b
.
prototype
=
{
constructor
:
b
,
refresh
:
function
(){
var
b
=
this
,
c
;
this
.
offsets
=
a
([]),
this
.
targets
=
a
([]),
c
=
this
.
$body
.
find
(
this
.
selector
).
map
(
function
(){
var
b
=
a
(
this
),
c
=
b
.
data
(
"target"
)
||
b
.
attr
(
"href"
),
d
=
/^#
\w
/
.
test
(
c
)
&&
a
(
c
);
return
d
&&
c
.
length
&&
[[
d
.
position
().
top
,
c
]]
||
null
}).
sort
(
function
(
a
,
b
){
return
a
[
0
]
-
b
[
0
]}).
each
(
function
(){
b
.
offsets
.
push
(
this
[
0
]),
b
.
targets
.
push
(
this
[
1
])})},
process
:
function
(){
var
a
=
this
.
$scrollElement
.
scrollTop
()
+
this
.
options
.
offset
,
b
=
this
.
$scrollElement
[
0
].
scrollHeight
||
this
.
$body
[
0
].
scrollHeight
,
c
=
b
-
this
.
$scrollElement
.
height
(),
d
=
this
.
offsets
,
e
=
this
.
targets
,
f
=
this
.
activeTarget
,
g
;
if
(
a
>=
c
)
return
f
!=
(
g
=
e
.
last
()[
0
])
&&
this
.
activate
(
g
);
for
(
g
=
d
.
length
;
g
--
;)
f
!=
e
[
g
]
&&
a
>=
d
[
g
]
&&
(
!
d
[
g
+
1
]
||
a
<=
d
[
g
+
1
])
&&
this
.
activate
(
e
[
g
])},
activate
:
function
(
b
){
var
c
,
d
;
this
.
activeTarget
=
b
,
a
(
this
.
selector
).
parent
(
".active"
).
removeClass
(
"active"
),
d
=
this
.
selector
+
'[data-target="'
+
b
+
'"],'
+
this
.
selector
+
'[href="'
+
b
+
'"]'
,
c
=
a
(
d
).
parent
(
"li"
).
addClass
(
"active"
),
c
.
parent
(
".dropdown-menu"
)
&&
(
c
=
c
.
closest
(
"li.dropdown"
).
addClass
(
"active"
)),
c
.
trigger
(
"activate"
)}},
a
.
fn
.
scrollspy
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"scrollspy"
),
f
=
typeof
c
==
"object"
&&
c
;
e
||
d
.
data
(
"scrollspy"
,
e
=
new
b
(
this
,
f
)),
typeof
c
==
"string"
&&
e
[
c
]()})},
a
.
fn
.
scrollspy
.
Constructor
=
b
,
a
.
fn
.
scrollspy
.
defaults
=
{
offset
:
10
},
a
(
function
(){
a
(
'[data-spy="scroll"]'
).
each
(
function
(){
var
b
=
a
(
this
);
b
.
scrollspy
(
b
.
data
())})})}(
window
.
jQuery
),
!
function
(
a
){
"use strict"
;
var
b
=
function
(
b
){
this
.
element
=
a
(
b
)};
b
.
prototype
=
{
constructor
:
b
,
show
:
function
(){
var
b
=
this
.
element
,
c
=
b
.
closest
(
"ul:not(.dropdown-menu)"
),
d
=
b
.
attr
(
"data-target"
),
e
,
f
,
g
;
d
||
(
d
=
b
.
attr
(
"href"
),
d
=
d
&&
d
.
replace
(
/.*
(?=
#
[^\s]
*$
)
/
,
""
));
if
(
b
.
parent
(
"li"
).
hasClass
(
"active"
))
return
;
e
=
c
.
find
(
".active a"
).
last
()[
0
],
g
=
a
.
Event
(
"show"
,{
relatedTarget
:
e
}),
b
.
trigger
(
g
);
if
(
g
.
isDefaultPrevented
())
return
;
f
=
a
(
d
),
this
.
activate
(
b
.
parent
(
"li"
),
c
),
this
.
activate
(
f
,
f
.
parent
(),
function
(){
b
.
trigger
({
type
:
"shown"
,
relatedTarget
:
e
})})},
activate
:
function
(
b
,
c
,
d
){
function
g
(){
e
.
removeClass
(
"active"
).
find
(
"> .dropdown-menu > .active"
).
removeClass
(
"active"
),
b
.
addClass
(
"active"
),
f
?(
b
[
0
].
offsetWidth
,
b
.
addClass
(
"in"
)):
b
.
removeClass
(
"fade"
),
b
.
parent
(
".dropdown-menu"
)
&&
b
.
closest
(
"li.dropdown"
).
addClass
(
"active"
),
d
&&
d
()}
var
e
=
c
.
find
(
"> .active"
),
f
=
d
&&
a
.
support
.
transition
&&
e
.
hasClass
(
"fade"
);
f
?
e
.
one
(
a
.
support
.
transition
.
end
,
g
):
g
(),
e
.
removeClass
(
"in"
)}},
a
.
fn
.
tab
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"tab"
);
e
||
d
.
data
(
"tab"
,
e
=
new
b
(
this
)),
typeof
c
==
"string"
&&
e
[
c
]()})},
a
.
fn
.
tab
.
Constructor
=
b
,
a
(
function
(){
a
(
"body"
).
on
(
"click.tab.data-api"
,
'[data-toggle="tab"], [data-toggle="pill"]'
,
function
(
b
){
b
.
preventDefault
(),
a
(
this
).
tab
(
"show"
)})})}(
window
.
jQuery
),
!
function
(
a
){
"use strict"
;
var
b
=
function
(
b
,
c
){
this
.
$element
=
a
(
b
),
this
.
options
=
a
.
extend
({},
a
.
fn
.
typeahead
.
defaults
,
c
),
this
.
matcher
=
this
.
options
.
matcher
||
this
.
matcher
,
this
.
sorter
=
this
.
options
.
sorter
||
this
.
sorter
,
this
.
highlighter
=
this
.
options
.
highlighter
||
this
.
highlighter
,
this
.
updater
=
this
.
options
.
updater
||
this
.
updater
,
this
.
$menu
=
a
(
this
.
options
.
menu
).
appendTo
(
"body"
),
this
.
source
=
this
.
options
.
source
,
this
.
shown
=!
1
,
this
.
listen
()};
b
.
prototype
=
{
constructor
:
b
,
select
:
function
(){
var
a
=
this
.
$menu
.
find
(
".active"
).
attr
(
"data-value"
);
return
this
.
$element
.
val
(
this
.
updater
(
a
)).
change
(),
this
.
hide
()},
updater
:
function
(
a
){
return
a
},
show
:
function
(){
var
b
=
a
.
extend
({},
this
.
$element
.
offset
(),{
height
:
this
.
$element
[
0
].
offsetHeight
});
return
this
.
$menu
.
css
({
top
:
b
.
top
+
b
.
height
,
left
:
b
.
left
}),
this
.
$menu
.
show
(),
this
.
shown
=!
0
,
this
},
hide
:
function
(){
return
this
.
$menu
.
hide
(),
this
.
shown
=!
1
,
this
},
lookup
:
function
(
b
){
var
c
=
this
,
d
,
e
;
return
this
.
query
=
this
.
$element
.
val
(),
this
.
query
?(
d
=
a
.
grep
(
this
.
source
,
function
(
a
){
return
c
.
matcher
(
a
)}),
d
=
this
.
sorter
(
d
),
d
.
length
?
this
.
render
(
d
.
slice
(
0
,
this
.
options
.
items
)).
show
():
this
.
shown
?
this
.
hide
():
this
):
this
.
shown
?
this
.
hide
():
this
},
matcher
:
function
(
a
){
return
~
a
.
toLowerCase
().
indexOf
(
this
.
query
.
toLowerCase
())},
sorter
:
function
(
a
){
var
b
=
[],
c
=
[],
d
=
[],
e
;
while
(
e
=
a
.
shift
())
e
.
toLowerCase
().
indexOf
(
this
.
query
.
toLowerCase
())?
~
e
.
indexOf
(
this
.
query
)?
c
.
push
(
e
):
d
.
push
(
e
):
b
.
push
(
e
);
return
b
.
concat
(
c
,
d
)},
highlighter
:
function
(
a
){
var
b
=
this
.
query
.
replace
(
/
[\-\[\]
{}()*+?.,
\\\^
$|#
\s]
/g
,
"
\\
$&"
);
return
a
.
replace
(
new
RegExp
(
"("
+
b
+
")"
,
"ig"
),
function
(
a
,
b
){
return
"<strong>"
+
b
+
"</strong>"
})},
render
:
function
(
b
){
var
c
=
this
;
return
b
=
a
(
b
).
map
(
function
(
b
,
d
){
return
b
=
a
(
c
.
options
.
item
).
attr
(
"data-value"
,
d
),
b
.
find
(
"a"
).
html
(
c
.
highlighter
(
d
)),
b
[
0
]}),
b
.
first
().
addClass
(
"active"
),
this
.
$menu
.
html
(
b
),
this
},
next
:
function
(
b
){
var
c
=
this
.
$menu
.
find
(
".active"
).
removeClass
(
"active"
),
d
=
c
.
next
();
d
.
length
||
(
d
=
a
(
this
.
$menu
.
find
(
"li"
)[
0
])),
d
.
addClass
(
"active"
)},
prev
:
function
(
a
){
var
b
=
this
.
$menu
.
find
(
".active"
).
removeClass
(
"active"
),
c
=
b
.
prev
();
c
.
length
||
(
c
=
this
.
$menu
.
find
(
"li"
).
last
()),
c
.
addClass
(
"active"
)},
listen
:
function
(){
this
.
$element
.
on
(
"blur"
,
a
.
proxy
(
this
.
blur
,
this
)).
on
(
"keypress"
,
a
.
proxy
(
this
.
keypress
,
this
)).
on
(
"keyup"
,
a
.
proxy
(
this
.
keyup
,
this
)),(
a
.
browser
.
webkit
||
a
.
browser
.
msie
)
&&
this
.
$element
.
on
(
"keydown"
,
a
.
proxy
(
this
.
keypress
,
this
)),
this
.
$menu
.
on
(
"click"
,
a
.
proxy
(
this
.
click
,
this
)).
on
(
"mouseenter"
,
"li"
,
a
.
proxy
(
this
.
mouseenter
,
this
))},
keyup
:
function
(
a
){
switch
(
a
.
keyCode
){
case
40
:
case
38
:
break
;
case
9
:
case
13
:
if
(
!
this
.
shown
)
return
;
this
.
select
();
break
;
case
27
:
if
(
!
this
.
shown
)
return
;
this
.
hide
();
break
;
default
:
this
.
lookup
()}
a
.
stopPropagation
(),
a
.
preventDefault
()},
keypress
:
function
(
a
){
if
(
!
this
.
shown
)
return
;
switch
(
a
.
keyCode
){
case
9
:
case
13
:
case
27
:
a
.
preventDefault
();
break
;
case
38
:
if
(
a
.
type
!=
"keydown"
)
break
;
a
.
preventDefault
(),
this
.
prev
();
break
;
case
40
:
if
(
a
.
type
!=
"keydown"
)
break
;
a
.
preventDefault
(),
this
.
next
()}
a
.
stopPropagation
()},
blur
:
function
(
a
){
var
b
=
this
;
setTimeout
(
function
(){
b
.
hide
()},
150
)},
click
:
function
(
a
){
a
.
stopPropagation
(),
a
.
preventDefault
(),
this
.
select
()},
mouseenter
:
function
(
b
){
this
.
$menu
.
find
(
".active"
).
removeClass
(
"active"
),
a
(
b
.
currentTarget
).
addClass
(
"active"
)}},
a
.
fn
.
typeahead
=
function
(
c
){
return
this
.
each
(
function
(){
var
d
=
a
(
this
),
e
=
d
.
data
(
"typeahead"
),
f
=
typeof
c
==
"object"
&&
c
;
e
||
d
.
data
(
"typeahead"
,
e
=
new
b
(
this
,
f
)),
typeof
c
==
"string"
&&
e
[
c
]()})},
a
.
fn
.
typeahead
.
defaults
=
{
source
:[],
items
:
8
,
menu
:
'<ul class="typeahead dropdown-menu"></ul>'
,
item
:
'<li><a href="#"></a></li>'
},
a
.
fn
.
typeahead
.
Constructor
=
b
,
a
(
function
(){
a
(
"body"
).
on
(
"focus.typeahead.data-api"
,
'[data-provide="typeahead"]'
,
function
(
b
){
var
c
=
a
(
this
);
if
(
c
.
data
(
"typeahead"
))
return
;
b
.
preventDefault
(),
c
.
typeahead
(
c
.
data
())})})}(
window
.
jQuery
);
\ No newline at end of file
lms/static/sass/course/wiki/_wiki.scss
View file @
ad45a44a
...
@@ -368,6 +368,8 @@ section.wiki {
...
@@ -368,6 +368,8 @@ section.wiki {
font-size
:
0
.8em
;
font-size
:
0
.8em
;
margin-right
:
5px
;
margin-right
:
5px
;
line-height
:
1
.2em
;
line-height
:
1
.2em
;
text-transform
:
none
!
important
;
letter-spacing
:
0
!
important
;
&
:hover
{
&
:hover
{
text-decoration
:
none
;
text-decoration
:
none
;
...
@@ -382,6 +384,15 @@ section.wiki {
...
@@ -382,6 +384,15 @@ section.wiki {
@include
button
(
simple
,
$pink
);
@include
button
(
simple
,
$pink
);
font-size
:
0
.8em
;
font-size
:
0
.8em
;
}
}
&
.btn-info
{
@include
button
(
simple
,
#ccc
);
font-size
:
0
.8em
;
}
}
a
.btn
{
padding
:
7px
18px
8px
!
important
;
}
}
.modal
{
.modal
{
...
@@ -453,13 +464,13 @@ section.wiki {
...
@@ -453,13 +464,13 @@ section.wiki {
text-decoration
:
none
;
text-decoration
:
none
;
}
}
}
}
}
.collapse
{
.collapse
{
display
:
none
;
display
:
none
;
&
.in
{
&
.in
{
display
:
block
;
display
:
block
;
}
}
}
}
}
...
...
lms/templates/wiki/base.html
View file @
ad45a44a
...
@@ -5,7 +5,28 @@
...
@@ -5,7 +5,28 @@
{% block headextra %}
{% block headextra %}
{% compressed_css 'course' %}
{% compressed_css 'course' %}
<script
src=
"{{ STATIC_URL }}js/bootstrap-modal.js"
></script>
<script
src=
"{{ STATIC_URL }}js/bootstrap.min.js"
></script>
<script
type=
"text/javascript"
>
function
ajaxError
(){}
$
.
ajaxSetup
({
timeout
:
7000
,
cache
:
false
,
error
:
function
(
e
,
xhr
,
settings
,
exception
)
{
ajaxError
();
}
});
function
jsonWrapper
(
url
,
callback
)
{
$
.
getJSON
(
url
,
function
(
data
)
{
if
(
data
==
null
)
{
ajaxError
();
}
else
{
callback
(
data
);
}
});
}
</script>
{% endblock %}
{% endblock %}
...
...
lms/templates/wiki/settings.html
0 → 100644
View file @
ad45a44a
{% extends "wiki/base.html" %}
{% load wiki_tags i18n %}
{% load url from future %}
{% block pagetitle %}{% trans "Settings" %}: {{ article.current_revision.title }}{% endblock %}
{% block wiki_breadcrumbs %}
{% include "wiki/includes/breadcrumbs.html" %}
{% endblock %}
{% block wiki_contents %}
<div
class=
"article-wrapper"
>
<article
class=
"main-article"
>
{% if selected_tab != "edit" %}
<h1>
{{ article.current_revision.title }}
</h1>
{% endif %}
{% for form in forms %}
<form
method=
"POST"
class=
"form-horizontal"
id=
"settings_form"
action=
"?f={{form.action}}"
>
<h2>
{{ form.settings_form_headline }}
</h2>
<div
class=
"well"
>
{% wiki_form form %}
</div>
<div
class=
"form-actions"
>
<button
type=
"submit"
name=
"save"
value=
"1"
class=
"btn btn-large btn-primary"
>
<span
class=
"icon-ok"
></span>
{% trans "Save changes" %}
</button>
</div>
</form>
{% endfor %}
</article>
<div
class=
"article-functions"
>
<div
class=
"timestamp"
>
<span
class=
"label"
>
{% trans "Last modified:" %}
</span><br
/>
<span
class=
"date"
>
{{ article.current_revision.modified }}
</span>
</div>
<ul
class=
"nav nav-tabs"
>
{% with "settings" as selected %}
{% include "wiki/includes/article_menu.html" %}
{% endwith %}
</ul>
</div>
</div>
{% endblock %}
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