Replace the language selector by our custom dropdown menu
This commit is contained in:
parent
26dd4ea11f
commit
569ea21705
@ -1,39 +0,0 @@
|
|||||||
/*
|
|
||||||
globals define
|
|
||||||
*/
|
|
||||||
define([
|
|
||||||
'/customize/languageSelector.js',
|
|
||||||
'/customize/messages.js',
|
|
||||||
'/bower_components/jquery/dist/jquery.min.js'
|
|
||||||
], function (LS, Messages) {
|
|
||||||
var $ = window.jQuery;
|
|
||||||
var main = function () {
|
|
||||||
var url = window.location.pathname;
|
|
||||||
var isHtml = /\.html/.test(url) || url === '/' || url === '';
|
|
||||||
if (!isHtml) {
|
|
||||||
Messages._applyTranslation();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
$.ajax({
|
|
||||||
url: isHtml ? '/customize/BottomBar.html' : '/customize/Header.html',
|
|
||||||
success: function (ret) {
|
|
||||||
var $bar = $(ret);
|
|
||||||
$('body').append($bar);
|
|
||||||
|
|
||||||
var $sel = $bar.find('#language-selector');
|
|
||||||
|
|
||||||
Object.keys(Messages._languages).forEach(function (code) {
|
|
||||||
$sel.append($('<option>', {
|
|
||||||
value: code,
|
|
||||||
}).text(Messages._languages[code]));
|
|
||||||
});
|
|
||||||
|
|
||||||
LS.main();
|
|
||||||
Messages._applyTranslation();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
};
|
|
||||||
return {
|
|
||||||
main: main
|
|
||||||
};
|
|
||||||
});
|
|
||||||
@ -4,6 +4,7 @@
|
|||||||
<title data-localization="main_title">Cryptpad: Zero Knowledge, Collaborative Real Time Editing</title>
|
<title data-localization="main_title">Cryptpad: Zero Knowledge, Collaborative Real Time Editing</title>
|
||||||
<meta content="text/html; charset=utf-8" http-equiv="content-type"/>
|
<meta content="text/html; charset=utf-8" http-equiv="content-type"/>
|
||||||
<link rel="stylesheet" type="text/css" href="/customize/main.css" />
|
<link rel="stylesheet" type="text/css" href="/customize/main.css" />
|
||||||
|
<link rel="stylesheet" href="/bower_components/components-font-awesome/css/font-awesome.min.css">
|
||||||
<link rel="icon" type="image/png" href="/customize/main-favicon.png" id="favicon"/>
|
<link rel="icon" type="image/png" href="/customize/main-favicon.png" id="favicon"/>
|
||||||
<script data-main="/customize/main" src="/bower_components/requirejs/require.js"></script>
|
<script data-main="/customize/main" src="/bower_components/requirejs/require.js"></script>
|
||||||
<script src="/bower_components/requirejs/require.js"></script>
|
<script src="/bower_components/requirejs/require.js"></script>
|
||||||
@ -19,7 +20,13 @@
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
<select id="language-selector" style="display: none;"></select>
|
<span id="language-selector" class="dropdown-bar">
|
||||||
|
<button>
|
||||||
|
<span class="buttonTitle" data-localozation="language"></span>
|
||||||
|
<span class="fa fa-caret-down"></span>
|
||||||
|
</button>
|
||||||
|
<div class="left cryptpad-dropdown dropdown-bar-content"></div>
|
||||||
|
</span>
|
||||||
|
|
||||||
<div id="main">
|
<div id="main">
|
||||||
<center>
|
<center>
|
||||||
|
|||||||
@ -4,6 +4,7 @@
|
|||||||
<title data-localization="main_title">Cryptpad: Zero Knowledge, Collaborative Real Time Editing</title>
|
<title data-localization="main_title">Cryptpad: Zero Knowledge, Collaborative Real Time Editing</title>
|
||||||
<meta content="text/html; charset=utf-8" http-equiv="content-type"/>
|
<meta content="text/html; charset=utf-8" http-equiv="content-type"/>
|
||||||
<link rel="stylesheet" type="text/css" href="/customize/main.css" />
|
<link rel="stylesheet" type="text/css" href="/customize/main.css" />
|
||||||
|
<link rel="stylesheet" href="/bower_components/components-font-awesome/css/font-awesome.min.css">
|
||||||
<link rel="icon" type="image/png" href="/customize/main-favicon.png" id="favicon"/>
|
<link rel="icon" type="image/png" href="/customize/main-favicon.png" id="favicon"/>
|
||||||
<script data-main="/customize/main" src="/bower_components/requirejs/require.js"></script>
|
<script data-main="/customize/main" src="/bower_components/requirejs/require.js"></script>
|
||||||
<script src="/bower_components/requirejs/require.js"></script>
|
<script src="/bower_components/requirejs/require.js"></script>
|
||||||
@ -19,7 +20,13 @@
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
<select id="language-selector" style="display: none;"></select>
|
<span id="language-selector" class="dropdown-bar">
|
||||||
|
<button>
|
||||||
|
<span class="buttonTitle" data-localozation="language"></span>
|
||||||
|
<span class="fa fa-caret-down"></span>
|
||||||
|
</button>
|
||||||
|
<div class="left cryptpad-dropdown dropdown-bar-content"></div>
|
||||||
|
</span>
|
||||||
|
|
||||||
<div id="main">
|
<div id="main">
|
||||||
<center>
|
<center>
|
||||||
|
|||||||
@ -22,27 +22,28 @@ define(['/bower_components/jquery/dist/jquery.min.js'], function() {
|
|||||||
|
|
||||||
var main = out.main = function ($select) {
|
var main = out.main = function ($select) {
|
||||||
var selector = $select || $('#language-selector');
|
var selector = $select || $('#language-selector');
|
||||||
|
|
||||||
if (!selector.length) { return; }
|
if (!selector.length) { return; }
|
||||||
|
|
||||||
|
var $button = $(selector).find('button .buttonTitle');
|
||||||
// Select the current language in the list
|
// Select the current language in the list
|
||||||
var language = getLanguage();
|
var language = getLanguage();
|
||||||
var option = $(selector).find('option[value="' + language + '"]');
|
var option = $(selector).find('[data-value="' + language + '"]');
|
||||||
if ($(option).length) {
|
if ($(option).length) {
|
||||||
$(selector).val(language);
|
$button.text($(option).text());
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
$(selector).val('en');
|
$button.text('English');
|
||||||
}
|
}
|
||||||
|
|
||||||
// Listen for language change
|
// Listen for language change
|
||||||
$(selector).on('change', function () {
|
$(selector).find('a.languageValue').on('click', function () {
|
||||||
var newLanguage = $(selector).val();
|
var newLanguage = $(this).attr('data-value');
|
||||||
storeLanguage(newLanguage);
|
storeLanguage(newLanguage);
|
||||||
if (newLanguage !== language) {
|
if (newLanguage !== language) {
|
||||||
window.location.reload();
|
window.location.reload();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
return out;
|
return out;
|
||||||
|
|||||||
@ -329,6 +329,49 @@
|
|||||||
.cp #loading .spinnerContainer > div {
|
.cp #loading .spinnerContainer > div {
|
||||||
height: 100px;
|
height: 100px;
|
||||||
}
|
}
|
||||||
|
/* The container <div> - needed to position the dropdown content */
|
||||||
|
.dropdown-bar {
|
||||||
|
position: relative;
|
||||||
|
display: inline-block;
|
||||||
|
}
|
||||||
|
.dropdown-bar button .fa {
|
||||||
|
margin-left: 5px;
|
||||||
|
}
|
||||||
|
.dropdown-bar .dropdown-bar-content {
|
||||||
|
display: none;
|
||||||
|
position: absolute;
|
||||||
|
background-color: #f9f9f9;
|
||||||
|
min-width: 160px;
|
||||||
|
box-shadow: 0px 1px 5px 0px rgba(0, 0, 0, 0.2);
|
||||||
|
z-index: 1000;
|
||||||
|
}
|
||||||
|
.dropdown-bar .dropdown-bar-content.left {
|
||||||
|
right: 0;
|
||||||
|
}
|
||||||
|
.dropdown-bar .dropdown-bar-content:hover {
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
.dropdown-bar .dropdown-bar-content a {
|
||||||
|
color: black;
|
||||||
|
padding: 5px 16px;
|
||||||
|
text-decoration: none;
|
||||||
|
display: block;
|
||||||
|
cursor: pointer;
|
||||||
|
-webkit-user-select: none;
|
||||||
|
-moz-user-select: none;
|
||||||
|
-ms-user-select: none;
|
||||||
|
user-select: none;
|
||||||
|
float: none;
|
||||||
|
text-align: left;
|
||||||
|
}
|
||||||
|
.dropdown-bar .dropdown-bar-content a:hover {
|
||||||
|
background-color: #f1f1f1;
|
||||||
|
}
|
||||||
|
.dropdown-bar .dropdown-bar-content hr {
|
||||||
|
margin: 5px 0px;
|
||||||
|
height: 1px;
|
||||||
|
background: #bbb;
|
||||||
|
}
|
||||||
html.cp,
|
html.cp,
|
||||||
.cp body {
|
.cp body {
|
||||||
font-size: .875em;
|
font-size: .875em;
|
||||||
|
|||||||
@ -37,17 +37,28 @@ define([
|
|||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// Language selector
|
||||||
var $sel = $('#language-selector');
|
var $sel = $('#language-selector');
|
||||||
|
var $innerblock = $sel.find(".dropdown-bar-content");
|
||||||
Object.keys(Messages._languages).forEach(function (code) {
|
var $button = $sel.find('button');
|
||||||
$sel.append($('<option>', {
|
var languages = Messages._languages;
|
||||||
value: code,
|
for (var l in languages) {
|
||||||
}).text(Messages._languages[code]));
|
$('<a>', {
|
||||||
|
'class': 'languageValue',
|
||||||
|
'data-value': l,
|
||||||
|
'href': '#',
|
||||||
|
}).text(languages[l]).appendTo($innerblock);
|
||||||
|
}
|
||||||
|
$button.click(function (e) {
|
||||||
|
e.stopPropagation();
|
||||||
|
$innerblock.toggle();
|
||||||
});
|
});
|
||||||
|
LS.main($sel);
|
||||||
LS.main();
|
|
||||||
Messages._applyTranslation();
|
Messages._applyTranslation();
|
||||||
$sel.show();
|
$sel.show();
|
||||||
|
$(window).click(function () {
|
||||||
|
$innerblock.hide();
|
||||||
|
});
|
||||||
|
|
||||||
var makeRecentPadsTable = function (recentPads) {
|
var makeRecentPadsTable = function (recentPads) {
|
||||||
if (!recentPads.length) { return; }
|
if (!recentPads.length) { return; }
|
||||||
|
|||||||
@ -4,6 +4,7 @@
|
|||||||
<title data-localization="main_title">Cryptpad: Zero Knowledge, Collaborative Real Time Editing</title>
|
<title data-localization="main_title">Cryptpad: Zero Knowledge, Collaborative Real Time Editing</title>
|
||||||
<meta content="text/html; charset=utf-8" http-equiv="content-type"/>
|
<meta content="text/html; charset=utf-8" http-equiv="content-type"/>
|
||||||
<link rel="stylesheet" type="text/css" href="/customize/main.css" />
|
<link rel="stylesheet" type="text/css" href="/customize/main.css" />
|
||||||
|
<link rel="stylesheet" href="/bower_components/components-font-awesome/css/font-awesome.min.css">
|
||||||
<link rel="icon" type="image/png" href="/customize/main-favicon.png" id="favicon"/>
|
<link rel="icon" type="image/png" href="/customize/main-favicon.png" id="favicon"/>
|
||||||
<script data-main="/customize/main" src="/bower_components/requirejs/require.js"></script>
|
<script data-main="/customize/main" src="/bower_components/requirejs/require.js"></script>
|
||||||
<script src="/bower_components/requirejs/require.js"></script>
|
<script src="/bower_components/requirejs/require.js"></script>
|
||||||
@ -19,7 +20,13 @@
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
<select id="language-selector" style="display: none;"></select>
|
<span id="language-selector" class="dropdown-bar">
|
||||||
|
<button>
|
||||||
|
<span class="buttonTitle" data-localozation="language"></span>
|
||||||
|
<span class="fa fa-caret-down"></span>
|
||||||
|
</button>
|
||||||
|
<div class="left cryptpad-dropdown dropdown-bar-content"></div>
|
||||||
|
</span>
|
||||||
|
|
||||||
<div id="main">
|
<div id="main">
|
||||||
<center>
|
<center>
|
||||||
|
|||||||
@ -4,6 +4,7 @@
|
|||||||
@import "./alertify.less";
|
@import "./alertify.less";
|
||||||
@import "./bar.less";
|
@import "./bar.less";
|
||||||
@import "./loading.less";
|
@import "./loading.less";
|
||||||
|
@import "./dropdown.less";
|
||||||
|
|
||||||
html.cp, .cp body {
|
html.cp, .cp body {
|
||||||
font-size: .875em;
|
font-size: .875em;
|
||||||
|
|||||||
62
customize.dist/src/less/dropdown.less
Normal file
62
customize.dist/src/less/dropdown.less
Normal file
@ -0,0 +1,62 @@
|
|||||||
|
|
||||||
|
/* The container <div> - needed to position the dropdown content */
|
||||||
|
.dropdown-bar {
|
||||||
|
position: relative;
|
||||||
|
display: inline-block;
|
||||||
|
|
||||||
|
.dropbtn {
|
||||||
|
}
|
||||||
|
|
||||||
|
&:hover {
|
||||||
|
.dropbtn {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
button {
|
||||||
|
.fa{
|
||||||
|
margin-left: 5px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.dropdown-bar-content {
|
||||||
|
display: none;
|
||||||
|
position: absolute;
|
||||||
|
background-color: #f9f9f9;
|
||||||
|
min-width: 160px;
|
||||||
|
box-shadow: 0px 1px 5px 0px rgba(0, 0, 0, 0.2);
|
||||||
|
z-index: 1000;
|
||||||
|
|
||||||
|
&.left {
|
||||||
|
right: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
&:hover {
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
|
||||||
|
a {
|
||||||
|
color: black;
|
||||||
|
padding: 5px 16px;
|
||||||
|
text-decoration: none;
|
||||||
|
display: block;
|
||||||
|
cursor: pointer;
|
||||||
|
-webkit-user-select: none;
|
||||||
|
-moz-user-select: none;
|
||||||
|
-ms-user-select: none;
|
||||||
|
user-select: none;
|
||||||
|
float: none;
|
||||||
|
text-align: left;
|
||||||
|
|
||||||
|
&:hover {
|
||||||
|
background-color: #f1f1f1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
hr {
|
||||||
|
margin: 5px 0px;
|
||||||
|
height: 1px;
|
||||||
|
background: #bbb;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@ -1,6 +1,8 @@
|
|||||||
@import "./variables.less";
|
@import "./variables.less";
|
||||||
@import "./mixins.less";
|
@import "./mixins.less";
|
||||||
|
|
||||||
|
@import "./dropdown.less";
|
||||||
|
|
||||||
.unselectable {
|
.unselectable {
|
||||||
-webkit-touch-callout: none;
|
-webkit-touch-callout: none;
|
||||||
-webkit-user-select: none;
|
-webkit-user-select: none;
|
||||||
|
|||||||
@ -4,6 +4,7 @@
|
|||||||
<title data-localization="main_title">Cryptpad: Zero Knowledge, Collaborative Real Time Editing</title>
|
<title data-localization="main_title">Cryptpad: Zero Knowledge, Collaborative Real Time Editing</title>
|
||||||
<meta content="text/html; charset=utf-8" http-equiv="content-type"/>
|
<meta content="text/html; charset=utf-8" http-equiv="content-type"/>
|
||||||
<link rel="stylesheet" type="text/css" href="/customize/main.css" />
|
<link rel="stylesheet" type="text/css" href="/customize/main.css" />
|
||||||
|
<link rel="stylesheet" href="/bower_components/components-font-awesome/css/font-awesome.min.css">
|
||||||
<link rel="icon" type="image/png" href="/customize/main-favicon.png" id="favicon"/>
|
<link rel="icon" type="image/png" href="/customize/main-favicon.png" id="favicon"/>
|
||||||
<script data-main="/customize/main" src="/bower_components/requirejs/require.js"></script>
|
<script data-main="/customize/main" src="/bower_components/requirejs/require.js"></script>
|
||||||
<script src="/bower_components/requirejs/require.js"></script>
|
<script src="/bower_components/requirejs/require.js"></script>
|
||||||
@ -16,7 +17,13 @@
|
|||||||
<body>
|
<body>
|
||||||
{{fork}}
|
{{fork}}
|
||||||
|
|
||||||
<select id="language-selector" style="display: none;"></select>
|
<span id="language-selector" class="dropdown-bar">
|
||||||
|
<button>
|
||||||
|
<span class="buttonTitle" data-localozation="language"></span>
|
||||||
|
<span class="fa fa-caret-down"></span>
|
||||||
|
</button>
|
||||||
|
<div class="left cryptpad-dropdown dropdown-bar-content"></div>
|
||||||
|
</span>
|
||||||
|
|
||||||
<div id="main">
|
<div id="main">
|
||||||
{{logo}}
|
{{logo}}
|
||||||
|
|||||||
@ -4,6 +4,7 @@
|
|||||||
<title data-localization="main_title">Cryptpad: Zero Knowledge, Collaborative Real Time Editing</title>
|
<title data-localization="main_title">Cryptpad: Zero Knowledge, Collaborative Real Time Editing</title>
|
||||||
<meta content="text/html; charset=utf-8" http-equiv="content-type"/>
|
<meta content="text/html; charset=utf-8" http-equiv="content-type"/>
|
||||||
<link rel="stylesheet" type="text/css" href="/customize/main.css" />
|
<link rel="stylesheet" type="text/css" href="/customize/main.css" />
|
||||||
|
<link rel="stylesheet" href="/bower_components/components-font-awesome/css/font-awesome.min.css">
|
||||||
<link rel="icon" type="image/png" href="/customize/main-favicon.png" id="favicon"/>
|
<link rel="icon" type="image/png" href="/customize/main-favicon.png" id="favicon"/>
|
||||||
<script data-main="/customize/main" src="/bower_components/requirejs/require.js"></script>
|
<script data-main="/customize/main" src="/bower_components/requirejs/require.js"></script>
|
||||||
<script src="/bower_components/requirejs/require.js"></script>
|
<script src="/bower_components/requirejs/require.js"></script>
|
||||||
@ -19,7 +20,13 @@
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
<select id="language-selector" style="display: none;"></select>
|
<span id="language-selector" class="dropdown-bar">
|
||||||
|
<button>
|
||||||
|
<span class="buttonTitle" data-localozation="language"></span>
|
||||||
|
<span class="fa fa-caret-down"></span>
|
||||||
|
</button>
|
||||||
|
<div class="left cryptpad-dropdown dropdown-bar-content"></div>
|
||||||
|
</span>
|
||||||
|
|
||||||
<div id="main">
|
<div id="main">
|
||||||
<center>
|
<center>
|
||||||
|
|||||||
@ -1,3 +1,46 @@
|
|||||||
|
/* The container <div> - needed to position the dropdown content */
|
||||||
|
.dropdown-bar {
|
||||||
|
position: relative;
|
||||||
|
display: inline-block;
|
||||||
|
}
|
||||||
|
.dropdown-bar button .fa {
|
||||||
|
margin-left: 5px;
|
||||||
|
}
|
||||||
|
.dropdown-bar .dropdown-bar-content {
|
||||||
|
display: none;
|
||||||
|
position: absolute;
|
||||||
|
background-color: #f9f9f9;
|
||||||
|
min-width: 160px;
|
||||||
|
box-shadow: 0px 1px 5px 0px rgba(0, 0, 0, 0.2);
|
||||||
|
z-index: 1000;
|
||||||
|
}
|
||||||
|
.dropdown-bar .dropdown-bar-content.left {
|
||||||
|
right: 0;
|
||||||
|
}
|
||||||
|
.dropdown-bar .dropdown-bar-content:hover {
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
.dropdown-bar .dropdown-bar-content a {
|
||||||
|
color: black;
|
||||||
|
padding: 5px 16px;
|
||||||
|
text-decoration: none;
|
||||||
|
display: block;
|
||||||
|
cursor: pointer;
|
||||||
|
-webkit-user-select: none;
|
||||||
|
-moz-user-select: none;
|
||||||
|
-ms-user-select: none;
|
||||||
|
user-select: none;
|
||||||
|
float: none;
|
||||||
|
text-align: left;
|
||||||
|
}
|
||||||
|
.dropdown-bar .dropdown-bar-content a:hover {
|
||||||
|
background-color: #f1f1f1;
|
||||||
|
}
|
||||||
|
.dropdown-bar .dropdown-bar-content hr {
|
||||||
|
margin: 5px 0px;
|
||||||
|
height: 1px;
|
||||||
|
background: #bbb;
|
||||||
|
}
|
||||||
.unselectable {
|
.unselectable {
|
||||||
-webkit-touch-callout: none;
|
-webkit-touch-callout: none;
|
||||||
-webkit-user-select: none;
|
-webkit-user-select: none;
|
||||||
|
|||||||
@ -42,6 +42,8 @@ define(function () {
|
|||||||
out.editor = "éditeur";
|
out.editor = "éditeur";
|
||||||
out.editors = "éditeurs";
|
out.editors = "éditeurs";
|
||||||
|
|
||||||
|
out.language = "Langue";
|
||||||
|
|
||||||
out.greenLight = "Tout fonctionne bien";
|
out.greenLight = "Tout fonctionne bien";
|
||||||
out.orangeLight = "Votre connexion est lente, ce qui réduit la qualité de l'éditeur";
|
out.orangeLight = "Votre connexion est lente, ce qui réduit la qualité de l'éditeur";
|
||||||
out.redLight = "Vous êtes déconnectés de la session";
|
out.redLight = "Vous êtes déconnectés de la session";
|
||||||
|
|||||||
@ -44,6 +44,8 @@ define(function () {
|
|||||||
out.editor = "editor";
|
out.editor = "editor";
|
||||||
out.editors = "editors";
|
out.editors = "editors";
|
||||||
|
|
||||||
|
out.language = "Language";
|
||||||
|
|
||||||
out.greenLight = "Everything is working fine";
|
out.greenLight = "Everything is working fine";
|
||||||
out.orangeLight = "Your slow connection may impact your experience";
|
out.orangeLight = "Your slow connection may impact your experience";
|
||||||
out.redLight = "You are disconnected from the session";
|
out.redLight = "You are disconnected from the session";
|
||||||
|
|||||||
@ -368,26 +368,43 @@ define([
|
|||||||
|
|
||||||
$userContainer.append($lag);
|
$userContainer.append($lag);
|
||||||
|
|
||||||
var $span = $('<span>' , {
|
// Dropdown language selector
|
||||||
'class': 'cryptpad-language'
|
var $fa_caretdown = $('<span>', {
|
||||||
|
'class': 'fa fa-caret-down',
|
||||||
});
|
});
|
||||||
var $select = $('<select>', {
|
|
||||||
'id': 'language-selector'
|
var $block = $('<span>', {
|
||||||
}).appendTo($userContainer);
|
'class': 'dropdown-bar',
|
||||||
|
id: 'language-selector'
|
||||||
|
});
|
||||||
|
var $button = $('<button>', {
|
||||||
|
'class': ''
|
||||||
|
}).append($('<span>', {'class': 'buttonTitle'}).text(Messages.language)).append($fa_caretdown);
|
||||||
|
|
||||||
|
var $innerblock = $('<div>', {'class': 'left cryptpad-dropdown dropdown-bar-content'});
|
||||||
|
|
||||||
var languages = Messages._languages;
|
var languages = Messages._languages;
|
||||||
for (var l in languages) {
|
for (var l in languages) {
|
||||||
$('<option>', {
|
$('<a>', {
|
||||||
value: l
|
'class': 'languageValue',
|
||||||
}).text(languages[l]).appendTo($select);
|
'data-value': l,
|
||||||
|
'href': '#',
|
||||||
|
}).text(languages[l]).appendTo($innerblock);
|
||||||
}
|
}
|
||||||
|
$block.append($button).append($innerblock);
|
||||||
|
$button.click(function (e) {
|
||||||
|
e.stopPropagation();
|
||||||
|
$innerblock.toggle();
|
||||||
|
});
|
||||||
|
$block.appendTo($userContainer);
|
||||||
|
|
||||||
Messages._initSelector($select);
|
Messages._initSelector($block);
|
||||||
|
// End language selector
|
||||||
|
|
||||||
$select.on('mousedown', function (e) {
|
/*$select.on('mousedown', function (e) {
|
||||||
e.stopPropagation();
|
e.stopPropagation();
|
||||||
return true;
|
return true;
|
||||||
});
|
});*/
|
||||||
|
|
||||||
var $usernameElement = $('<span>', {'class': USERNAME_CLS}).appendTo($userContainer);
|
var $usernameElement = $('<span>', {'class': USERNAME_CLS}).appendTo($userContainer);
|
||||||
|
|
||||||
|
|||||||
@ -348,73 +348,27 @@ button.newElement:hover {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* Style The Dropdown Button */
|
|
||||||
.dropbtn {
|
|
||||||
background-color: #4CAF50;
|
|
||||||
color: white;
|
|
||||||
padding: 16px;
|
|
||||||
font-size: 16px;
|
|
||||||
border: none;
|
|
||||||
cursor: pointer;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* The container <div> - needed to position the dropdown content */
|
/* The container <div> - needed to position the dropdown content */
|
||||||
.dropdown-bar {
|
#driveToolbar .dropdown-bar {
|
||||||
margin: 4px 5px;
|
margin: 4px 5px;
|
||||||
position: relative;
|
position: relative;
|
||||||
display: inline-block;
|
display: inline-block;
|
||||||
}
|
}
|
||||||
.dropdown-bar.right {
|
#driveToolbar .dropdown-bar.right {
|
||||||
float: right;
|
float: right;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Right-side buttons */
|
/* Right-side buttons */
|
||||||
.dropdown-bar.right button {
|
#driveToolbar .dropdown-bar.right button {
|
||||||
display: inline-block;
|
display: inline-block;
|
||||||
}
|
}
|
||||||
.dropdown-bar.right button.active {
|
#driveToolbar .dropdown-bar.right button.active {
|
||||||
display: none;
|
display: none;
|
||||||
}
|
}
|
||||||
.dropdown-bar.right button .fa {
|
#driveToolbar .dropdown-bar.right button .fa {
|
||||||
margin-right: 0px;
|
margin-right: 0px;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Dropdown Content (Hidden by Default) */
|
|
||||||
.dropdown-bar-content {
|
.dropdown-bar-content {
|
||||||
display: none;
|
margin-top: -3px;
|
||||||
position: absolute;
|
margin-right: 2px;
|
||||||
background-color: #f9f9f9;
|
|
||||||
min-width: 160px;
|
|
||||||
box-shadow: 0px 8px 16px 0px rgba(0,0,0,0.2);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Links inside the dropdown */
|
|
||||||
.dropdown-bar-content a {
|
|
||||||
color: black;
|
|
||||||
padding: 5px 16px;
|
|
||||||
text-decoration: none;
|
|
||||||
display: block;
|
|
||||||
cursor: pointer;
|
|
||||||
-webkit-user-select: none;
|
|
||||||
-moz-user-select: none;
|
|
||||||
-ms-user-select: none;
|
|
||||||
user-select: none;
|
|
||||||
}
|
|
||||||
.dropdown-bar-content hr {
|
|
||||||
margin: 5px 0px;
|
|
||||||
height: 1px;
|
|
||||||
background: #bbb;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Change color of dropdown links on hover */
|
|
||||||
.dropdown-bar-content a:hover {background-color: #f1f1f1}
|
|
||||||
|
|
||||||
/* Show the dropdown menu on hover */
|
|
||||||
..dropdown-bar-content:hover {
|
|
||||||
display: block;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Change the background color of the dropdown button when the dropdown content is shown */
|
|
||||||
.dropdown-bar:hover .dropbtn {
|
|
||||||
background-color: #3e8e41;
|
|
||||||
}
|
}
|
||||||
|
|||||||
@ -7,6 +7,7 @@
|
|||||||
<script src="/bower_components/bootstrap/dist/js/bootstrap.min.js"></script>
|
<script src="/bower_components/bootstrap/dist/js/bootstrap.min.js"></script>
|
||||||
<link rel="stylesheet" href="/bower_components/bootstrap/dist/css/bootstrap.min.css">
|
<link rel="stylesheet" href="/bower_components/bootstrap/dist/css/bootstrap.min.css">
|
||||||
<link rel="stylesheet" href="file.css" />
|
<link rel="stylesheet" href="file.css" />
|
||||||
|
<link rel="stylesheet" href="/customize/main.css" />
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<div id="toolbar" class="toolbar-container"></div>
|
<div id="toolbar" class="toolbar-container"></div>
|
||||||
|
|||||||
@ -106,8 +106,12 @@ define([
|
|||||||
// document itself and causes problems when it's sent across the wire and reflected back
|
// document itself and causes problems when it's sent across the wire and reflected back
|
||||||
removePlugins: 'resize',
|
removePlugins: 'resize',
|
||||||
extraPlugins: 'autolink,colorbutton,colordialog,font',
|
extraPlugins: 'autolink,colorbutton,colordialog,font',
|
||||||
//skin: 'moono',
|
toolbarGroups: [{"name":"clipboard","groups":["clipboard","undo"]},{"name":"editing","groups":["find","selection"]},{"name":"links"},{"name":"insert"},{"name":"forms"},{"name":"tools"},{"name":"document","groups":["mode","document","doctools"]},{"name":"others"},{"name":"basicstyles","groups":["basicstyles","cleanup"]},{"name":"paragraph","groups":["list","indent","blocks","align","bidi"]},{"name":"styles"},{"name":"colors"}],
|
||||||
toolbarGroups: [{"name":"clipboard","groups":["clipboard","undo"]},{"name":"editing","groups":["find","selection"]},{"name":"links"},{"name":"insert"},{"name":"forms"},{"name":"tools"},{"name":"document","groups":["mode","document","doctools"]},{"name":"others"},{"name":"basicstyles","groups":["basicstyles","cleanup"]},{"name":"paragraph","groups":["list","indent","blocks","align","bidi"]},{"name":"styles"},{"name":"colors"}]
|
//skin: 'moono-cryptpad,/pad/themes/moono-cryptpad/'
|
||||||
|
//skin: 'flat,/pad/themes/flat/'
|
||||||
|
//skin: 'moono-lisa,/pad/themes/moono-lisa/'
|
||||||
|
//skin: 'moono-dark,/pad/themes/moono-dark/'
|
||||||
|
//skin: 'office2013,/pad/themes/office2013/'
|
||||||
});
|
});
|
||||||
|
|
||||||
editor.on('instanceReady', function (Ckeditor) {
|
editor.on('instanceReady', function (Ckeditor) {
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user