Upgrade to Bootstrap 3
This commit is contained in:
parent
05d92e0808
commit
902f857c4e
@ -108,8 +108,6 @@ define([
|
|||||||
delete folderList[folderDesc.folderIndex];
|
delete folderList[folderDesc.folderIndex];
|
||||||
});
|
});
|
||||||
eventMgr.onFoldersChanged();
|
eventMgr.onFoldersChanged();
|
||||||
|
|
||||||
refreshManager();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
var liMoveElt = undefined;
|
var liMoveElt = undefined;
|
||||||
@ -232,11 +230,10 @@ define([
|
|||||||
var fileDesc = fileSystem[parentElt.data('fileIndex')];
|
var fileDesc = fileSystem[parentElt.data('fileIndex')];
|
||||||
if(name && folderDesc && name != folderDesc.name) {
|
if(name && folderDesc && name != folderDesc.name) {
|
||||||
folderDesc.name = name;
|
folderDesc.name = name;
|
||||||
refreshManager();
|
eventMgr.onFoldersChanged();
|
||||||
}
|
}
|
||||||
else if(name && fileDesc && name != fileDesc.title) {
|
else if(name && fileDesc && name != fileDesc.title) {
|
||||||
fileDesc.title = name;
|
fileDesc.title = name;
|
||||||
refreshManager();
|
|
||||||
eventMgr.onTitleChanged(fileDesc);
|
eventMgr.onTitleChanged(fileDesc);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
@ -286,6 +283,7 @@ define([
|
|||||||
documentManager.onSyncRemoved = refreshManager;
|
documentManager.onSyncRemoved = refreshManager;
|
||||||
documentManager.onNewPublishSuccess = refreshManager;
|
documentManager.onNewPublishSuccess = refreshManager;
|
||||||
documentManager.onPublishRemoved = refreshManager;
|
documentManager.onPublishRemoved = refreshManager;
|
||||||
|
documentManager.onFoldersChanged = refreshManager;
|
||||||
|
|
||||||
documentManager.onReady = function() {
|
documentManager.onReady = function() {
|
||||||
modalElt = document.querySelector('.modal-document-manager');
|
modalElt = document.querySelector('.modal-document-manager');
|
||||||
@ -318,12 +316,11 @@ define([
|
|||||||
// Add the index to the folder list
|
// Add the index to the folder list
|
||||||
utils.appendIndexToArray("folder.list", folderIndex);
|
utils.appendIndexToArray("folder.list", folderIndex);
|
||||||
folderList[folderIndex] = folderDesc;
|
folderList[folderIndex] = folderDesc;
|
||||||
|
eventMgr.onFoldersChanged();
|
||||||
refreshManager();
|
|
||||||
|
|
||||||
// Edit the name when folder has just been created
|
// Edit the name when folder has just been created
|
||||||
var renameButtonElt = $(modalElt.querySelector('[data-folder-index="' + folderIndex + '"] .button-rename')).click();
|
var renameButtonElt = $(modalElt.querySelector('[data-folder-index="' + folderIndex + '"] .button-rename')).click();
|
||||||
modalElt.scrollTop = modalElt.scrollTop + renameButtonElt.offset().top - 50;
|
modalElt.scrollTop += renameButtonElt.offset().top - 50;
|
||||||
});
|
});
|
||||||
|
|
||||||
// Selection dropdown menu actions
|
// Selection dropdown menu actions
|
||||||
@ -390,8 +387,6 @@ define([
|
|||||||
});
|
});
|
||||||
eventMgr.onFoldersChanged();
|
eventMgr.onFoldersChanged();
|
||||||
|
|
||||||
refreshManager();
|
|
||||||
|
|
||||||
$(modalElt.querySelectorAll('.document-list')).removeClass('hide');
|
$(modalElt.querySelectorAll('.document-list')).removeClass('hide');
|
||||||
$(modalElt.querySelectorAll('.choose-folder, .select-folder-list')).addClass('hide');
|
$(modalElt.querySelectorAll('.choose-folder, .select-folder-list')).addClass('hide');
|
||||||
});
|
});
|
||||||
|
@ -41,6 +41,9 @@ define([
|
|||||||
|
|
||||||
var panelElt = undefined;
|
var panelElt = undefined;
|
||||||
var documentListElt = undefined;
|
var documentListElt = undefined;
|
||||||
|
var $documentListElt = undefined;
|
||||||
|
var documentListFilteredElt = undefined;
|
||||||
|
var $documentListFilteredElt = undefined;
|
||||||
var refreshPanel = function() {
|
var refreshPanel = function() {
|
||||||
|
|
||||||
// List orphan documents
|
// List orphan documents
|
||||||
@ -79,6 +82,18 @@ define([
|
|||||||
|
|
||||||
documentListElt.innerHTML = documentListHtml;
|
documentListElt.innerHTML = documentListHtml;
|
||||||
|
|
||||||
|
// Create filtered list
|
||||||
|
var documentListFilteredHtml = _.chain(fileSystem).sortBy(function(fileDesc) {
|
||||||
|
return fileDesc.title.toLowerCase();
|
||||||
|
}).reduce(function(result, fileDesc) {
|
||||||
|
return result + '<li>' + _.template(documentEltTmpl, {
|
||||||
|
fileDesc: fileDesc,
|
||||||
|
}) + '</li>';
|
||||||
|
}, '').value();
|
||||||
|
documentListFilteredHtml = '<ul class="nav">' + documentListFilteredHtml + '</ul>';
|
||||||
|
|
||||||
|
documentListFilteredElt.innerHTML = documentListFilteredHtml;
|
||||||
|
|
||||||
// Add click listeners
|
// Add click listeners
|
||||||
_.each(documentListElt.querySelectorAll('.file'), function(fileElt) {
|
_.each(documentListElt.querySelectorAll('.file'), function(fileElt) {
|
||||||
fileElt = $(fileElt);
|
fileElt = $(fileElt);
|
||||||
@ -107,37 +122,73 @@ define([
|
|||||||
documentPanel.onFoldersChanged = refreshPanel;
|
documentPanel.onFoldersChanged = refreshPanel;
|
||||||
|
|
||||||
// Filter for search input in file selector
|
// Filter for search input in file selector
|
||||||
function filterFileSelector(filter) {
|
var panelContentElt = undefined;
|
||||||
var liList = $(".file-selector > li");
|
var previousFilterValue = '';
|
||||||
liList.show();
|
function filterFiles(filterValue) {
|
||||||
if(filter) {
|
if(filterValue == previousFilterValue) {
|
||||||
var words = filter.toLowerCase().split(/\s+/);
|
return;
|
||||||
liList.each(function() {
|
|
||||||
var fileTitle = $(this).text().toLowerCase();
|
|
||||||
if(_.some(words, function(word) {
|
|
||||||
return fileTitle.indexOf(word) === -1;
|
|
||||||
})) {
|
|
||||||
$(this).hide();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
previousFilterValue = filterValue;
|
||||||
|
|
||||||
|
// Scroll to top
|
||||||
|
panelContentElt.scrollTop = 0;
|
||||||
|
|
||||||
|
if(!filterValue) {
|
||||||
|
$documentListFilteredElt.addClass('hide');
|
||||||
|
$documentListElt.removeClass('hide');
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
var wordList = filterValue.toLowerCase().split(/\s+/);
|
||||||
|
_.each(documentListFilteredElt.querySelectorAll('.file'), function(fileElt) {
|
||||||
|
var $fileElt = $(fileElt);
|
||||||
|
var fileTitle = $fileElt.text().toLowerCase();
|
||||||
|
$fileElt.toggle(!_.some(wordList, function(word) {
|
||||||
|
return fileTitle.indexOf(word) === -1;
|
||||||
|
}));
|
||||||
|
});
|
||||||
|
$documentListFilteredElt.removeClass('hide');
|
||||||
|
$documentListElt.addClass('hide');
|
||||||
}
|
}
|
||||||
|
|
||||||
documentPanel.onReady = function() {
|
documentPanel.onReady = function() {
|
||||||
panelElt = document.querySelector('.document-panel');
|
panelElt = document.querySelector('.document-panel');
|
||||||
documentListElt = panelElt.querySelector('.list-group');
|
panelContentElt = panelElt.querySelector('.panel-content');
|
||||||
|
documentListElt = panelElt.querySelector('.document-list');
|
||||||
|
$documentListElt = $(documentListElt);
|
||||||
|
documentListFilteredElt = panelElt.querySelector('.document-list-filtered');
|
||||||
|
$documentListFilteredElt = $(documentListFilteredElt);
|
||||||
|
|
||||||
// Open current folder before opening
|
// Open current folder before opening
|
||||||
$(panelElt).on('show.bs.collapse', function(e) {
|
$(panelElt).on('show.bs.collapse', function(e) {
|
||||||
var folderDesc = selectedFileDesc.folder;
|
if(e.target === panelElt) {
|
||||||
if(e.target === panelElt && folderDesc !== undefined) {
|
var folderDesc = selectedFileDesc.folder;
|
||||||
$(panelElt.querySelector('.file-list.' + folderDesc.folderIndex.replace('.', ''))).collapse('show');
|
if(folderDesc !== undefined) {
|
||||||
|
$(panelElt.querySelector('.file-list.' + folderDesc.folderIndex.replace('.', ''))).collapse('show');
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}).on('shown.bs.collapse', function(e) {
|
}).on('shown.bs.collapse', function(e) {
|
||||||
// Scroll to the active file
|
|
||||||
if(e.target === panelElt) {
|
if(e.target === panelElt) {
|
||||||
|
// Unset the filter
|
||||||
|
$filterInputElt.val('');
|
||||||
|
filterFiles('');
|
||||||
|
|
||||||
|
// Scroll to the active file
|
||||||
|
panelContentElt.scrollTop += documentListElt.querySelector('.file.active').getBoundingClientRect().top - 100;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// Search bar input change
|
||||||
|
var $filterInputElt = $(panelElt.querySelector('.search-bar .form-control'));
|
||||||
|
$filterInputElt.bind("propertychange keyup input paste", function() {
|
||||||
|
filterFiles($filterInputElt.val());
|
||||||
|
});
|
||||||
|
|
||||||
|
// Clear button
|
||||||
|
$(panelElt.querySelector('.search-bar .close')).click(function() {
|
||||||
|
$filterInputElt.val('');
|
||||||
|
filterFiles('');
|
||||||
|
$filterInputElt.focus();
|
||||||
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
return documentPanel;
|
return documentPanel;
|
||||||
|
@ -141,17 +141,21 @@
|
|||||||
data-target=".document-panel" title="Select document">
|
data-target=".document-panel" title="Select document">
|
||||||
<i class="icon-folder-open"></i> <i class="icon-right-dir"></i>
|
<i class="icon-folder-open"></i> <i class="icon-right-dir"></i>
|
||||||
</button>
|
</button>
|
||||||
<div class="panel-content">
|
<div class="search-bar clearfix">
|
||||||
<div class="input-group">
|
<div class="input-group">
|
||||||
<span class="input-group-addon"><i class="icon-search"></i></span><input
|
<span class="input-group-addon"><i class="icon-search"></i></span><input
|
||||||
type="text" class="form-control"></input>
|
type="text" class="form-control"></input>
|
||||||
|
<button type="button" class="close" title="clear">×</button>
|
||||||
<div class="input-group-btn">
|
<div class="input-group-btn">
|
||||||
<a data-toggle="modal" data-target=".modal-document-manager"
|
<a data-toggle="modal" data-target=".modal-document-manager"
|
||||||
class="btn btn-default" title="Manage documents"><i
|
class="btn btn-default" title="Manage documents"><i
|
||||||
class="icon-layers"></i></a>
|
class="icon-layers"></i></a>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="panel-content">
|
||||||
<div class="list-group document-list"></div>
|
<div class="list-group document-list"></div>
|
||||||
|
<div class="list-group document-list-filtered hide"></div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
@text-light: #888;
|
@text-light: #888;
|
||||||
@error-border: #ff8661;
|
@error-border: #ff8661;
|
||||||
@menu-panel-width: 280px;
|
@menu-panel-width: 280px;
|
||||||
@document-panel-width: 330px;
|
@document-panel-width: 350px;
|
||||||
@panel-bg: @bg-navbar-hover;
|
@panel-bg: @bg-navbar-hover;
|
||||||
@folder-color: #555;
|
@folder-color: #555;
|
||||||
@transparent: fade(#000, 0%);
|
@transparent: fade(#000, 0%);
|
||||||
@ -270,7 +270,6 @@ body {
|
|||||||
// Common style
|
// Common style
|
||||||
.menu-panel, .document-panel {
|
.menu-panel, .document-panel {
|
||||||
display: block;
|
display: block;
|
||||||
background-color: @panel-bg;
|
|
||||||
position: absolute;
|
position: absolute;
|
||||||
height: 100%;
|
height: 100%;
|
||||||
z-index: 10;
|
z-index: 10;
|
||||||
@ -281,8 +280,6 @@ body {
|
|||||||
font-size: 18px;
|
font-size: 18px;
|
||||||
}
|
}
|
||||||
.panel-content {
|
.panel-content {
|
||||||
padding-top: 6px;
|
|
||||||
padding-bottom: 25px;
|
|
||||||
overflow: auto;
|
overflow: auto;
|
||||||
height: 100%;
|
height: 100%;
|
||||||
a > i {
|
a > i {
|
||||||
@ -293,6 +290,7 @@ body {
|
|||||||
}
|
}
|
||||||
|
|
||||||
.menu-panel {
|
.menu-panel {
|
||||||
|
background-color: @panel-bg;
|
||||||
width: @menu-panel-width !important;
|
width: @menu-panel-width !important;
|
||||||
margin-left: (-@menu-panel-width - 32);
|
margin-left: (-@menu-panel-width - 32);
|
||||||
-webkit-transition: margin-left 0.35s ease;
|
-webkit-transition: margin-left 0.35s ease;
|
||||||
@ -313,6 +311,8 @@ body {
|
|||||||
z-index: -1;
|
z-index: -1;
|
||||||
}
|
}
|
||||||
.panel-content {
|
.panel-content {
|
||||||
|
padding-top: 6px;
|
||||||
|
padding-bottom: 25px;
|
||||||
border-right: 5px solid @preview-bg-light;
|
border-right: 5px solid @preview-bg-light;
|
||||||
.nav {
|
.nav {
|
||||||
margin-bottom: 20px;
|
margin-bottom: 20px;
|
||||||
@ -321,6 +321,7 @@ body {
|
|||||||
}
|
}
|
||||||
|
|
||||||
.document-panel {
|
.document-panel {
|
||||||
|
background-color: @list-group-bg;
|
||||||
right: 0;
|
right: 0;
|
||||||
width: @document-panel-width !important;
|
width: @document-panel-width !important;
|
||||||
margin-right: (-@document-panel-width - 32);
|
margin-right: (-@document-panel-width - 32);
|
||||||
@ -349,9 +350,25 @@ body {
|
|||||||
.icon-layers {
|
.icon-layers {
|
||||||
font-size: 135%;
|
font-size: 135%;
|
||||||
}
|
}
|
||||||
.input-group {
|
}
|
||||||
background-color: @list-group-bg;
|
.search-bar {
|
||||||
padding: 15px 5px 15px 20px;
|
position: absolute;
|
||||||
|
background-color: @panel-bg;
|
||||||
|
margin: -10px 25px 0;
|
||||||
|
padding: 20px 5px 10px 20px;
|
||||||
|
z-index: 3;
|
||||||
|
border: 1px solid #e8e8e8;
|
||||||
|
border-top: 0;
|
||||||
|
border-radius: 6px;
|
||||||
|
.form-control {
|
||||||
|
padding: 8px 30px 8px 12px;
|
||||||
|
}
|
||||||
|
.close {
|
||||||
|
position: absolute;
|
||||||
|
line-height: 10px;
|
||||||
|
margin-left: -30px;
|
||||||
|
margin-top: 5px;
|
||||||
|
padding: 8px;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
.list-group-item {
|
.list-group-item {
|
||||||
@ -363,9 +380,14 @@ body {
|
|||||||
font-size: 15px;
|
font-size: 15px;
|
||||||
border-bottom-color: @modal-content-separator-color;
|
border-bottom-color: @modal-content-separator-color;
|
||||||
}
|
}
|
||||||
.list-group .nav {
|
.list-group {
|
||||||
border: 0;
|
padding-top: 70px;
|
||||||
margin: 0 20px 20px;
|
padding-bottom: 30px;
|
||||||
|
margin: 0;
|
||||||
|
.nav {
|
||||||
|
border: 0;
|
||||||
|
margin: 0 20px 20px;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user