Experiment with the new item pane UI
This commit is contained in:
parent
36cc18e8cf
commit
bb5075e8b8
19 changed files with 742 additions and 448 deletions
|
@ -1,10 +1,10 @@
|
||||||
/* Use standard tab appearance for item pane tabs */
|
/* Use standard tab appearance for item pane tabs */
|
||||||
#zotero-pane #zotero-view-tabbox > tabs > tab {
|
#zotero-pane .zotero-view-tabbox > tabs > tab {
|
||||||
-moz-appearance: tab;
|
-moz-appearance: tab;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Active tab label color in item pane and elsewhere */
|
/* Active tab label color in item pane and elsewhere */
|
||||||
#zotero-pane tabs#zotero-editpane-tabs > tab[visuallyselected="true"][selected="true"] hbox > .tab-text,
|
#zotero-pane tabs.zotero-editpane-tabs > tab[visuallyselected="true"][selected="true"] hbox > .tab-text,
|
||||||
#zotero-prefs tab[visuallyselected="true"]:not(:-moz-window-inactive),
|
#zotero-prefs tab[visuallyselected="true"]:not(:-moz-window-inactive),
|
||||||
tabs > tab[visuallyselected="true"] hbox > .tab-text {
|
tabs > tab[visuallyselected="true"] hbox > .tab-text {
|
||||||
color: black !important;
|
color: black !important;
|
||||||
|
|
|
@ -107,12 +107,12 @@ input {
|
||||||
margin: 0;
|
margin: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#zotero-view-tabbox {
|
.zotero-view-tabbox {
|
||||||
background-color: #fff;
|
background-color: #fff;
|
||||||
padding: 0;
|
padding: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#zotero-item-pane-content .groupbox-body {
|
.zotero-item-pane-content .groupbox-body {
|
||||||
-moz-appearance: none;
|
-moz-appearance: none;
|
||||||
background-color: #ffffff;
|
background-color: #ffffff;
|
||||||
}
|
}
|
||||||
|
@ -121,13 +121,13 @@ input {
|
||||||
color: #7f7f7f;
|
color: #7f7f7f;
|
||||||
}
|
}
|
||||||
|
|
||||||
#zotero-view-tabbox > tabpanels {
|
.zotero-view-tabbox > tabpanels {
|
||||||
margin: 12px 0 0 0;
|
margin: 12px 0 0 0;
|
||||||
padding: 0;
|
padding: 0;
|
||||||
-moz-appearance: none;
|
-moz-appearance: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
#zotero-editpane-tabs {
|
.zotero-editpane-tabs {
|
||||||
-moz-appearance: none;
|
-moz-appearance: none;
|
||||||
background: -moz-linear-gradient(top, #ededed, #cccccc);
|
background: -moz-linear-gradient(top, #ededed, #cccccc);
|
||||||
border-style: solid;
|
border-style: solid;
|
||||||
|
@ -136,15 +136,15 @@ input {
|
||||||
padding: 2px 0 2px 0;
|
padding: 2px 0 2px 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#zotero-editpane-tabs > tab > hbox {
|
.zotero-editpane-tabs > tab > hbox {
|
||||||
padding: 0;
|
padding: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#zotero-editpane-tabs > tab > hbox > .tab-icon {
|
.zotero-editpane-tabs > tab > hbox > .tab-icon {
|
||||||
display: none;
|
display: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
#zotero-editpane-tabs > tab {
|
.zotero-editpane-tabs > tab {
|
||||||
-moz-box-orient: vertical;
|
-moz-box-orient: vertical;
|
||||||
-moz-box-align: center;
|
-moz-box-align: center;
|
||||||
-moz-appearance: toolbarbutton;
|
-moz-appearance: toolbarbutton;
|
||||||
|
@ -153,7 +153,7 @@ input {
|
||||||
padding: 3px 1px 3px 1px;
|
padding: 3px 1px 3px 1px;
|
||||||
}
|
}
|
||||||
|
|
||||||
#zotero-editpane-tabs > tab > hbox .tab-text {
|
.zotero-editpane-tabs > tab > hbox .tab-text {
|
||||||
font-size: 11px;
|
font-size: 11px;
|
||||||
font-weight: bold;
|
font-weight: bold;
|
||||||
margin: 2px 7px 2px 9px !important;
|
margin: 2px 7px 2px 9px !important;
|
||||||
|
@ -161,11 +161,11 @@ input {
|
||||||
}
|
}
|
||||||
|
|
||||||
/* This seems to be necessary to center the tabs. Not sure why. */
|
/* This seems to be necessary to center the tabs. Not sure why. */
|
||||||
#zotero-editpane-tabs > tab:last-of-type > hbox .tab-text {
|
.zotero-editpane-tabs > tab:last-of-type > hbox .tab-text {
|
||||||
margin: 2px 9px 2px 9px !important;
|
margin: 2px 9px 2px 9px !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
#zotero-editpane-tabs > tab[selected=true] > hbox .tab-text {
|
.zotero-editpane-tabs > tab[selected=true] > hbox .tab-text {
|
||||||
color: #FFF !important;
|
color: #FFF !important;
|
||||||
text-shadow: rgba(0, 0, 0, 0.4) 0 1px;
|
text-shadow: rgba(0, 0, 0, 0.4) 0 1px;
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,20 +11,20 @@
|
||||||
visibility: visible;
|
visibility: visible;
|
||||||
}
|
}
|
||||||
|
|
||||||
#zotero-item-pane-content {
|
.zotero-item-pane-content {
|
||||||
margin-right: 6px;
|
margin-right: 6px;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Make the item pane appear white (same colour as treeview), making the UI more consistent */
|
/* Make the item pane appear white (same colour as treeview), making the UI more consistent */
|
||||||
#zotero-item-pane-content tab, #zotero-item-pane-content tabpanels {
|
.zotero-item-pane-content tab, .zotero-item-pane-content tabpanels {
|
||||||
background-color: -moz-Field; /* Same as background colour for treeview */
|
background-color: -moz-Field; /* Same as background colour for treeview */
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Possibly irrelevant if mozilla fixes https://bugzilla.mozilla.org/show_bug.cgi?id=1306425 */
|
/* Possibly irrelevant if mozilla fixes https://bugzilla.mozilla.org/show_bug.cgi?id=1306425 */
|
||||||
#zotero-view-tabbox tabs tab[visuallyselected=true] {
|
.zotero-view-tabbox tabs tab[visuallyselected=true] {
|
||||||
margin-top: 0px !important; /* Importanter than ./itemPane.css:20 */
|
margin-top: 0px !important; /* Importanter than ./itemPane.css:20 */
|
||||||
margin-bottom: -2px !important; /* Importanter than skin/itemPane.css:12 */
|
margin-bottom: -2px !important; /* Importanter than skin/itemPane.css:12 */
|
||||||
}
|
}
|
||||||
#zotero-view-tabbox tabs tab {
|
.zotero-view-tabbox tabs tab {
|
||||||
margin-top: 2px !important; /* Importanter than skin/itemPane.css:11 */
|
margin-top: 2px !important; /* Importanter than skin/itemPane.css:11 */
|
||||||
}
|
}
|
||||||
|
|
|
@ -49,7 +49,7 @@
|
||||||
padding-top: 4px;
|
padding-top: 4px;
|
||||||
}
|
}
|
||||||
|
|
||||||
#zotero-view-tabbox tab {
|
.zotero-view-tabbox tab {
|
||||||
padding-left: .7em;
|
padding-left: .7em;
|
||||||
padding-right: .7em;
|
padding-right: .7em;
|
||||||
}
|
}
|
||||||
|
@ -99,7 +99,7 @@
|
||||||
display: none;
|
display: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
#zotero-collections-tree, #zotero-items-tree, #zotero-view-item {
|
#zotero-collections-tree, #zotero-items-tree, .zotero-view-item {
|
||||||
-moz-appearance: none;
|
-moz-appearance: none;
|
||||||
border-style: solid;
|
border-style: solid;
|
||||||
border-color: #818790;
|
border-color: #818790;
|
||||||
|
@ -142,11 +142,11 @@ tree {
|
||||||
margin: .04em 0 0 .15em !important;
|
margin: .04em 0 0 .15em !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
#zotero-editpane-tabs spacer {
|
.zotero-editpane-tabs spacer {
|
||||||
border: 0;
|
border: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#zotero-view-item {
|
.zotero-view-item {
|
||||||
padding: 0 !important;
|
padding: 0 !important;
|
||||||
-moz-appearance: none;
|
-moz-appearance: none;
|
||||||
background-color: -moz-field;
|
background-color: -moz-field;
|
||||||
|
@ -154,7 +154,7 @@ tree {
|
||||||
border-color: var(--theme-border-color);
|
border-color: var(--theme-border-color);
|
||||||
}
|
}
|
||||||
|
|
||||||
#zotero-editpane-tabs {
|
.zotero-editpane-tabs {
|
||||||
margin-top: 2px;
|
margin-top: 2px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -163,8 +163,8 @@ tree {
|
||||||
border-width: 0;
|
border-width: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#zotero-editpane-item-box > scrollbox, #zotero-view-item > tabpanel > vbox,
|
.zotero-editpane-item-box > scrollbox, .zotero-view-item > tabpanel > vbox,
|
||||||
#zotero-editpane-tags > scrollbox, #zotero-editpane-related {
|
#zotero-editpane-tags > scrollbox, .zotero-editpane-related {
|
||||||
padding-top: 5px;
|
padding-top: 5px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -172,6 +172,6 @@ tree {
|
||||||
padding-left: 5px;
|
padding-left: 5px;
|
||||||
}
|
}
|
||||||
|
|
||||||
#zotero-view-item > tabpanel > vbox {
|
.zotero-view-item > tabpanel > vbox {
|
||||||
padding-left: 5px;
|
padding-left: 5px;
|
||||||
}
|
}
|
54
chrome/content/zotero/components/itemPane/notesList.jsx
Normal file
54
chrome/content/zotero/components/itemPane/notesList.jsx
Normal file
|
@ -0,0 +1,54 @@
|
||||||
|
/*
|
||||||
|
***** BEGIN LICENSE BLOCK *****
|
||||||
|
|
||||||
|
Copyright © 2020 Corporation for Digital Scholarship
|
||||||
|
Vienna, Virginia, USA
|
||||||
|
https://www.zotero.org
|
||||||
|
|
||||||
|
This file is part of Zotero.
|
||||||
|
|
||||||
|
Zotero is free software: you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU Affero General Public License as published by
|
||||||
|
the Free Software Foundation, either version 3 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
Zotero is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Affero General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Affero General Public License
|
||||||
|
along with Zotero. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
***** END LICENSE BLOCK *****
|
||||||
|
*/
|
||||||
|
|
||||||
|
import React, { forwardRef, useImperativeHandle, useState } from 'react';
|
||||||
|
|
||||||
|
const NoteRow = ({ title, body, date, onClick }) => {
|
||||||
|
return (
|
||||||
|
<div className="note-row" onClick={onClick}>
|
||||||
|
<div className="inner">
|
||||||
|
<div className="first-line">
|
||||||
|
<div className="title">{title}</div>
|
||||||
|
</div>
|
||||||
|
<div className="second-line">
|
||||||
|
<div className="date">{date}</div>
|
||||||
|
<div className="body">{body}</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
const NotesList = forwardRef(({ onClick }, ref) => {
|
||||||
|
const [notes, setNotes] = useState([]);
|
||||||
|
useImperativeHandle(ref, () => ({ setNotes }));
|
||||||
|
return (
|
||||||
|
<div className="notes-list">
|
||||||
|
{notes.map(note => <NoteRow key={note.id} {...note} onClick={() => onClick(note.id)}/>)}
|
||||||
|
</div>
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
|
export default NotesList;
|
|
@ -26,13 +26,15 @@
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import ReactDOM from 'react-dom';
|
import ReactDOM from 'react-dom';
|
||||||
import TagsBoxContainer from 'containers/tagsBoxContainer';
|
import TagsBoxContainer from 'containers/tagsBoxContainer';
|
||||||
|
import NotesList from 'components/itemPane/notesList';
|
||||||
|
|
||||||
var ZoteroItemPane = new function() {
|
var ZoteroItemPane = new function() {
|
||||||
var _lastItem, _itemBox, _notesLabel, _notesButton, _notesList, _tagsBox, _relatedBox;
|
var _lastItem, _itemBox, _notesLabel, _notesButton, _notesList, _tagsBox, _relatedBox;
|
||||||
var _selectedNoteID;
|
var _selectedNoteID;
|
||||||
var _translationTarget;
|
var _translationTarget;
|
||||||
var _noteIDs;
|
var _noteIDs;
|
||||||
var _recentlyPinned = [];
|
var _contextNoteUpdaters = [];
|
||||||
|
let _pdfTabHidden = false;
|
||||||
|
|
||||||
this.onLoad = function () {
|
this.onLoad = function () {
|
||||||
if (!Zotero) {
|
if (!Zotero) {
|
||||||
|
@ -64,7 +66,7 @@ var ZoteroItemPane = new function() {
|
||||||
document.getElementById('temp-toggle-2').addEventListener('click', () => {
|
document.getElementById('temp-toggle-2').addEventListener('click', () => {
|
||||||
this.togglePane();
|
this.togglePane();
|
||||||
});
|
});
|
||||||
this.initPinnedView();
|
this.initStandaloneNotesView();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -234,6 +236,10 @@ var ZoteroItemPane = new function() {
|
||||||
yield this.viewItem(_lastItem, null, 1);
|
yield this.viewItem(_lastItem, null, 1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
this.updateStandaloneNotesList();
|
||||||
|
for (let updater of _contextNoteUpdaters) {
|
||||||
|
updater.callback();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else if (type == 'tab') {
|
else if (type == 'tab') {
|
||||||
if (action == 'add') {
|
if (action == 'add') {
|
||||||
|
@ -301,6 +307,7 @@ var ZoteroItemPane = new function() {
|
||||||
// noteEditor.clearUndo();
|
// noteEditor.clearUndo();
|
||||||
// }
|
// }
|
||||||
|
|
||||||
|
document.getElementById('zotero-view-note-sidebar-button').hidden = !!item.parentID;
|
||||||
document.getElementById('zotero-view-note-button').hidden = !editable;
|
document.getElementById('zotero-view-note-button').hidden = !editable;
|
||||||
document.getElementById('zotero-item-pane-content').selectedIndex = 2;
|
document.getElementById('zotero-item-pane-content').selectedIndex = 2;
|
||||||
};
|
};
|
||||||
|
@ -310,6 +317,17 @@ var ZoteroItemPane = new function() {
|
||||||
// ZoteroPane.setItemPaneMessage(Zotero.getString('pane.item.notes.editingInWindow'));
|
// ZoteroPane.setItemPaneMessage(Zotero.getString('pane.item.notes.editingInWindow'));
|
||||||
};
|
};
|
||||||
|
|
||||||
|
this.openNoteSidebar = async function () {
|
||||||
|
var selectedNote = Zotero.Items.get(_selectedNoteID);
|
||||||
|
|
||||||
|
if (!selectedNote.parentID) {
|
||||||
|
let editor = document.getElementById('zotero-item-pane-pinned-note');
|
||||||
|
editor.mode = 'edit';
|
||||||
|
editor.item = selectedNote;
|
||||||
|
document.getElementById('zotero-item-pane-pin-deck2').setAttribute('selectedIndex', 1);
|
||||||
|
this.togglePane(false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Select the parent item and open the note editor
|
* Select the parent item and open the note editor
|
||||||
|
@ -457,7 +475,27 @@ var ZoteroItemPane = new function() {
|
||||||
elem.setAttribute('tooltiptext', tooltip);
|
elem.setAttribute('tooltiptext', tooltip);
|
||||||
};
|
};
|
||||||
|
|
||||||
this.getActiveNote = function() {
|
|
||||||
|
function _updateNoteCount() {
|
||||||
|
var c = _notesList.childNodes.length;
|
||||||
|
|
||||||
|
var str = 'pane.item.notes.count.';
|
||||||
|
switch (c){
|
||||||
|
case 0:
|
||||||
|
str += 'zero';
|
||||||
|
break;
|
||||||
|
case 1:
|
||||||
|
str += 'singular';
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
str += 'plural';
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
_notesLabel.value = Zotero.getString(str, [c]);
|
||||||
|
}
|
||||||
|
|
||||||
|
this.getActiveNote = function () {
|
||||||
let mainDeck = document.getElementById('zotero-item-pane-main-deck');
|
let mainDeck = document.getElementById('zotero-item-pane-main-deck');
|
||||||
if (mainDeck.selectedIndex == 0) {
|
if (mainDeck.selectedIndex == 0) {
|
||||||
let contextualDeck = document.getElementById('zotero-item-pane-contextual-deck');
|
let contextualDeck = document.getElementById('zotero-item-pane-contextual-deck');
|
||||||
|
@ -476,20 +514,8 @@ var ZoteroItemPane = new function() {
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
window.addEventListener('mousedown', () => {
|
this.togglePane = function (forceItem) {
|
||||||
Zotero.debug('active note')
|
|
||||||
Zotero.debug(this.getActiveNote())
|
|
||||||
});
|
|
||||||
|
|
||||||
this.pinNote = function(itemID) {
|
|
||||||
_recentlyPinned.unshift(itemID);
|
|
||||||
_recentlyPinned = _recentlyPinned.slice(0, 10);
|
|
||||||
this._setPinnedNote(itemID);
|
|
||||||
this._updatePinnedList();
|
|
||||||
}
|
|
||||||
|
|
||||||
this.togglePane = function(forceItem) {
|
|
||||||
let mainDeck = document.getElementById('zotero-item-pane-main-deck');
|
let mainDeck = document.getElementById('zotero-item-pane-main-deck');
|
||||||
let value;
|
let value;
|
||||||
if (forceItem !== undefined) {
|
if (forceItem !== undefined) {
|
||||||
|
@ -509,15 +535,16 @@ var ZoteroItemPane = new function() {
|
||||||
document.getElementById('temp-toggle-1').append('□ ■');
|
document.getElementById('temp-toggle-1').append('□ ■');
|
||||||
document.getElementById('temp-toggle-2').append('□ ■');
|
document.getElementById('temp-toggle-2').append('□ ■');
|
||||||
}
|
}
|
||||||
|
|
||||||
mainDeck.selectedIndex = value;
|
|
||||||
}
|
|
||||||
|
|
||||||
this.initPinnedView = async function () {
|
|
||||||
|
|
||||||
|
mainDeck.selectedIndex = value;
|
||||||
|
|
||||||
|
let contextualDeck = document.getElementById('zotero-item-pane-contextual-deck');
|
||||||
|
contextualDeck.children[contextualDeck.selectedIndex].setAttribute('state', value);
|
||||||
|
}
|
||||||
|
|
||||||
|
this.initStandaloneNotesView = async function () {
|
||||||
let container = document.getElementById('zotero-item-pane-pin-deck');
|
let container = document.getElementById('zotero-item-pane-pin-deck');
|
||||||
|
|
||||||
let bar = document.createElement('hbox');
|
let bar = document.createElement('hbox');
|
||||||
container.appendChild(bar);
|
container.appendChild(bar);
|
||||||
let inner = document.createElement('deck');
|
let inner = document.createElement('deck');
|
||||||
|
@ -525,109 +552,145 @@ var ZoteroItemPane = new function() {
|
||||||
inner.style.backgroundColor = 'white';
|
inner.style.backgroundColor = 'white';
|
||||||
inner.setAttribute('flex', 1);
|
inner.setAttribute('flex', 1);
|
||||||
container.appendChild(inner);
|
container.appendChild(inner);
|
||||||
|
|
||||||
let returnButton = document.createElement('toolbarbutton');
|
let returnButton = document.createElement('toolbarbutton');
|
||||||
returnButton.className = 'zotero-tb-button';
|
returnButton.className = 'zotero-tb-button';
|
||||||
returnButton.id = 'zotero-tb-return';
|
returnButton.id = 'zotero-tb-return';
|
||||||
returnButton.style.listStyleImage = "url('chrome://zotero/skin/citation-delete.png')"
|
returnButton.style.listStyleImage = 'url(\'chrome://zotero/skin/citation-delete.png\')'
|
||||||
returnButton.addEventListener('click', () => {
|
returnButton.addEventListener('click', () => {
|
||||||
inner.setAttribute('selectedIndex', 0);
|
inner.setAttribute('selectedIndex', 0);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
bar.append(returnButton, 'Pinned note');
|
bar.append(returnButton, 'Standalone Notes');
|
||||||
bar.style.overflowX = 'hidden';
|
bar.style.overflowX = 'hidden';
|
||||||
bar.style.textOverflow = 'ellipsis';
|
bar.style.textOverflow = 'ellipsis';
|
||||||
bar.style.fontWeight = 'bold';
|
bar.style.fontWeight = 'bold';
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
let list = document.createElement('vbox');
|
let list = document.createElement('vbox');
|
||||||
list.setAttribute('flex', 1);
|
list.setAttribute('flex', 1);
|
||||||
list.className = 'zotero-box';
|
list.className = 'zotero-box';
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
let note = document.createElement('zoteronoteeditor');
|
let note = document.createElement('zoteronoteeditor');
|
||||||
note.id = 'zotero-item-pane-pinned-note';
|
note.id = 'zotero-item-pane-pinned-note';
|
||||||
note.setAttribute('flex', 1);
|
note.setAttribute('flex', 1);
|
||||||
inner.appendChild(list);
|
inner.appendChild(list);
|
||||||
inner.appendChild(note);
|
inner.appendChild(note);
|
||||||
|
|
||||||
inner.setAttribute('selectedIndex', 0);
|
inner.setAttribute('selectedIndex', 0);
|
||||||
|
|
||||||
|
|
||||||
let head = document.createElement('hbox');
|
let head = document.createElement('hbox');
|
||||||
head.setAttribute('align', 'center');
|
|
||||||
let label = document.createElement('label');
|
let label = document.createElement('label');
|
||||||
let button = document.createElement('button');
|
let button = document.createElement('button');
|
||||||
button.setAttribute('label', 'Add');
|
button.setAttribute('label', Zotero.Intl.strings['zotero.item.add']);
|
||||||
button.addEventListener('click', async () => {
|
button.addEventListener('click', async () => {
|
||||||
inner.setAttribute('selectedIndex', 1);
|
inner.setAttribute('selectedIndex', 1);
|
||||||
let item = new Zotero.Item('note');
|
let item = new Zotero.Item('note');
|
||||||
item.libraryID = parentItem.libraryID;
|
item.libraryID = ZoteroPane_Local.getSelectedLibraryID();
|
||||||
item.parentKey = parentItem.key;
|
// item.parentKey = parentItem.key;
|
||||||
note.mode = 'edit';
|
note.mode = 'edit';
|
||||||
note.item = item;
|
note.item = item;
|
||||||
note.parentItem = null;
|
note.parentItem = null;
|
||||||
|
note.focus();
|
||||||
});
|
});
|
||||||
head.append(label, button);
|
|
||||||
|
|
||||||
let grid = document.createElement('grid');
|
head.style.paddingRight = '10px';
|
||||||
grid.setAttribute('flex', 1);
|
|
||||||
grid.style.overflowY = 'scroll';
|
|
||||||
let columns = document.createElement('columns');
|
|
||||||
let column1 = document.createElement('column');
|
|
||||||
column1.setAttribute('flex', 1);
|
|
||||||
let column2 = document.createElement('column');
|
|
||||||
columns.append(column1, column2);
|
|
||||||
grid.append(columns);
|
|
||||||
let rows = document.createElement('rows');
|
|
||||||
rows.setAttribute('flex', 1);
|
|
||||||
rows.id = 'zotero-item-pane-pinned-list';
|
|
||||||
grid.append(rows);
|
|
||||||
|
|
||||||
list.append(head, grid);
|
|
||||||
|
|
||||||
this._updatePinnedList();
|
let input = document.createElement('textbox');
|
||||||
}
|
input.setAttribute('type', 'search');
|
||||||
|
input.setAttribute('timeout', '250');
|
||||||
this._updatePinnedList = async function() {
|
|
||||||
let rows = document.getElementById('zotero-item-pane-pinned-list');
|
input.addEventListener('command', (event) => {
|
||||||
while (rows.hasChildNodes()) {
|
_updateStandaloneNotesList();
|
||||||
rows.removeChild(rows.firstChild);
|
})
|
||||||
|
|
||||||
|
|
||||||
|
let vbox1 = document.createElement('vbox');
|
||||||
|
vbox1.append(label, button);
|
||||||
|
|
||||||
|
let vbox2 = document.createElement('vbox');
|
||||||
|
vbox2.append(input);
|
||||||
|
|
||||||
|
head.append(vbox2, vbox1);
|
||||||
|
|
||||||
|
head.style.display = 'flex';
|
||||||
|
vbox2.style.flex = '1';
|
||||||
|
|
||||||
|
|
||||||
|
let listBox = document.createElement('vbox');
|
||||||
|
listBox.style.display = 'flex';
|
||||||
|
listBox.setAttribute('flex', '1')
|
||||||
|
|
||||||
|
const HTML_NS = 'http://www.w3.org/1999/xhtml';
|
||||||
|
var listInner = document.createElementNS(HTML_NS, 'div');
|
||||||
|
listInner.className = 'notes-list-container';
|
||||||
|
list.append(head, listBox);
|
||||||
|
|
||||||
|
listBox.append(listInner);
|
||||||
|
|
||||||
|
let noteListRef = React.createRef();
|
||||||
|
|
||||||
|
let _updateStandaloneNotesList = async (reset) => {
|
||||||
|
if (reset) {
|
||||||
|
input.value = '';
|
||||||
|
inner.setAttribute('selectedIndex', 0);
|
||||||
|
}
|
||||||
|
let text = input.value;
|
||||||
|
|
||||||
|
await Zotero.Schema.schemaUpdatePromise;
|
||||||
|
var s = new Zotero.Search();
|
||||||
|
s.addCondition('libraryID', 'is', ZoteroPane_Local.getSelectedLibraryID());
|
||||||
|
s.addCondition('itemType', 'is', 'note');
|
||||||
|
s.addCondition('noChildren', 'true');
|
||||||
|
if (text) {
|
||||||
|
s.addCondition('note', 'contains', text, true);
|
||||||
|
}
|
||||||
|
let notes = await s.search();
|
||||||
|
notes = Zotero.Items.get(notes);
|
||||||
|
notes.sort((a, b) => {
|
||||||
|
a = a.getField('dateModified');
|
||||||
|
b = b.getField('dateModified');
|
||||||
|
return b.localeCompare(a);
|
||||||
|
});
|
||||||
|
|
||||||
|
noteListRef.current.setNotes(notes.map(note => {
|
||||||
|
let text2 = note.note;
|
||||||
|
text2 = text2.trim();
|
||||||
|
// TODO: Fix a potential performance issuse
|
||||||
|
text2 = Zotero.Utilities.unescapeHTML(text2);
|
||||||
|
let parts = text2.split('\n').map(x => x.trim()).filter(x => x.length);
|
||||||
|
return {
|
||||||
|
id: note.id,
|
||||||
|
title: parts[0] || Zotero.getString('pane.item.notes.untitled'),
|
||||||
|
body: parts[1] || '',
|
||||||
|
date: (new Date(note.dateModified).toLocaleDateString(Zotero.locale))
|
||||||
|
};
|
||||||
|
}));
|
||||||
|
|
||||||
|
var c = notes.length;
|
||||||
|
var str = 'pane.item.notes.count.' + (c == 0 && 'zero' || c == 1 && 'singular' || 'plural');
|
||||||
|
label.value = Zotero.getString(str, [c]);
|
||||||
}
|
}
|
||||||
|
|
||||||
await Zotero.Schema.schemaUpdatePromise;
|
|
||||||
var s = new Zotero.Search();
|
|
||||||
s.addCondition('libraryID', 'is', 1);
|
|
||||||
s.addCondition('itemType', 'is', 'note');
|
|
||||||
s.addCondition('noChildren', 'true');
|
|
||||||
let notes = await s.search();
|
|
||||||
notes = Zotero.Items.get(notes);
|
|
||||||
notes.sort((a, b) => {
|
|
||||||
a = a.getField('dateModified');
|
|
||||||
b = b.getField('dateModified');
|
|
||||||
return b.localeCompare(a);
|
|
||||||
});
|
|
||||||
|
|
||||||
var row = document.createElement('row');
|
|
||||||
row.style.fontWeight = 'bold';
|
|
||||||
row.appendChild(document.createTextNode('Recently pinned notes'));
|
|
||||||
rows.append(row);
|
|
||||||
this._appendNoteRows(Zotero.Items.get(_recentlyPinned), rows, false, (id) => {
|
|
||||||
this._setPinnedNote(id);
|
|
||||||
});
|
|
||||||
|
|
||||||
row = document.createElement('row');
|
|
||||||
row.style.fontWeight = 'bold';
|
|
||||||
row.appendChild(document.createTextNode('Recently edited standalone notes'));
|
|
||||||
rows.append(row);
|
|
||||||
|
|
||||||
this._appendNoteRows(notes, rows, false, (id) => {
|
ReactDOM.render(
|
||||||
this._setPinnedNote(id);
|
<NotesList
|
||||||
});
|
ref={noteListRef}
|
||||||
|
onClick={(id) => {
|
||||||
|
this._setPinnedNote(id);
|
||||||
|
}}
|
||||||
|
/>,
|
||||||
|
listInner,
|
||||||
|
() => {
|
||||||
|
_updateStandaloneNotesList();
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
|
||||||
|
this.updateStandaloneNotesList = _updateStandaloneNotesList;
|
||||||
}
|
}
|
||||||
|
|
||||||
this._setPinnedNote = function (itemID) {
|
this._setPinnedNote = function (itemID) {
|
||||||
|
@ -683,132 +746,25 @@ var ZoteroItemPane = new function() {
|
||||||
list.appendChild(row);
|
list.appendChild(row);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
this.addPDFTabContext = function(tabID, itemID) {
|
this.removeTabContext = function (tabID) {
|
||||||
let contextualDeck = document.getElementById('zotero-item-pane-contextual-deck');
|
|
||||||
|
|
||||||
let container = document.createElement('vbox');
|
|
||||||
container.id = tabID + '-context';
|
|
||||||
|
|
||||||
let bar = document.createElement('hbox');
|
|
||||||
container.appendChild(bar);
|
|
||||||
let inner = document.createElement('deck');
|
|
||||||
inner.style.backgroundColor = 'white';
|
|
||||||
inner.setAttribute('flex', 1);
|
|
||||||
container.appendChild(inner);
|
|
||||||
|
|
||||||
contextualDeck.appendChild(container);
|
|
||||||
|
|
||||||
let item = Zotero.Items.get(itemID);
|
|
||||||
if (!item.parentID) {
|
|
||||||
inner.append("The PDF doesn't have a parent");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
let parentItem = Zotero.Items.get(item.parentID);
|
|
||||||
let returnButton = document.createElement('toolbarbutton');
|
|
||||||
returnButton.className = 'zotero-tb-button';
|
|
||||||
returnButton.id = 'zotero-tb-return';
|
|
||||||
returnButton.style.listStyleImage = "url('chrome://zotero/skin/citation-delete.png')"
|
|
||||||
returnButton.addEventListener('click', () => {
|
|
||||||
inner.setAttribute('selectedIndex', 0);
|
|
||||||
});
|
|
||||||
|
|
||||||
bar.append(returnButton, parentItem.getField('title'));
|
|
||||||
bar.style.overflowX = 'hidden';
|
|
||||||
bar.style.textOverflow = 'ellipsis';
|
|
||||||
bar.style.fontWeight = 'bold';
|
|
||||||
|
|
||||||
let list = document.createElement('vbox');
|
|
||||||
list.setAttribute('flex', 1);
|
|
||||||
list.className = 'zotero-box';
|
|
||||||
|
|
||||||
let note = document.createElement('zoteronoteeditor');
|
|
||||||
note.setAttribute('flex', 1);
|
|
||||||
inner.appendChild(list);
|
|
||||||
inner.appendChild(note);
|
|
||||||
inner.setAttribute('selectedIndex', 0);
|
|
||||||
|
|
||||||
note.placeholder = 'Drag annotations and write item-specific notes';
|
|
||||||
|
|
||||||
let head = document.createElement('hbox');
|
|
||||||
head.setAttribute('align', 'center');
|
|
||||||
let label = document.createElement('label');
|
|
||||||
let button = document.createElement('button');
|
|
||||||
button.setAttribute('label', 'Add');
|
|
||||||
button.addEventListener('click', async () => {
|
|
||||||
inner.setAttribute('selectedIndex', 1);
|
|
||||||
let item = new Zotero.Item('note');
|
|
||||||
item.libraryID = parentItem.libraryID;
|
|
||||||
item.parentKey = parentItem.key;
|
|
||||||
await item.saveTx();
|
|
||||||
note.mode = 'edit';
|
|
||||||
note.item = item;
|
|
||||||
note.parentItem = null;
|
|
||||||
_updateList();
|
|
||||||
});
|
|
||||||
head.append(label, button);
|
|
||||||
|
|
||||||
let grid = document.createElement('grid');
|
|
||||||
grid.setAttribute('flex', 1);
|
|
||||||
let columns = document.createElement('columns');
|
|
||||||
let column1 = document.createElement('column');
|
|
||||||
column1.setAttribute('flex', 1);
|
|
||||||
let column2 = document.createElement('column');
|
|
||||||
columns.append(column1, column2);
|
|
||||||
grid.append(columns);
|
|
||||||
let rows = document.createElement('rows');
|
|
||||||
rows.setAttribute('flex', 1);
|
|
||||||
grid.append(rows);
|
|
||||||
|
|
||||||
list.append(head, grid);
|
|
||||||
|
|
||||||
let parentNotes = parentItem.getNotes();
|
|
||||||
if (parentNotes.length == 0) {
|
|
||||||
inner.setAttribute('selectedIndex', 1);
|
|
||||||
let item = new Zotero.Item('note');
|
|
||||||
item.libraryID = parentItem.libraryID;
|
|
||||||
item.parentKey = parentItem.key;
|
|
||||||
note.mode = 'edit';
|
|
||||||
note.item = item;
|
|
||||||
note.parentItem = null;
|
|
||||||
}
|
|
||||||
else if (parentNotes.length == 1) {
|
|
||||||
inner.setAttribute('selectedIndex', 1);
|
|
||||||
note.mode = 'edit';
|
|
||||||
note.item = Zotero.Items.get(parentNotes[0]);
|
|
||||||
note.parentItem = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
let _updateList = () => {
|
|
||||||
while (rows.hasChildNodes()) {
|
|
||||||
rows.removeChild(rows.firstChild);
|
|
||||||
}
|
|
||||||
let parentNotes = Zotero.Items.get(parentItem.getNotes());
|
|
||||||
this._appendNoteRows(parentNotes, rows, true, (id) => {
|
|
||||||
inner.setAttribute('selectedIndex', 1);
|
|
||||||
note.mode = 'edit';
|
|
||||||
note.item = Zotero.Items.get(id);
|
|
||||||
note.parentItem = null;
|
|
||||||
}, (id) => {
|
|
||||||
ZoteroItemPane.removeNote(id);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
_updateList();
|
|
||||||
}
|
|
||||||
|
|
||||||
this.removeTabContext = function(tabID) {
|
|
||||||
document.getElementById(tabID + '-context').remove();
|
document.getElementById(tabID + '-context').remove();
|
||||||
|
_contextNoteUpdaters = _contextNoteUpdaters.filter(x => x.tabID != tabID);
|
||||||
};
|
};
|
||||||
|
|
||||||
this.selectTabContext = function(tabID, type) {
|
this.selectTabContext = function (tabID, type) {
|
||||||
let contextualDeck = document.getElementById('zotero-item-pane-contextual-deck');
|
let contextualDeck = document.getElementById('zotero-item-pane-contextual-deck');
|
||||||
|
let prevIndex = contextualDeck.selectedIndex;
|
||||||
contextualDeck.selectedIndex = Array.from(contextualDeck.children).findIndex(x => x.id == tabID + '-context');
|
contextualDeck.selectedIndex = Array.from(contextualDeck.children).findIndex(x => x.id == tabID + '-context');
|
||||||
|
|
||||||
let toolbar = document.getElementById('zotero-pane-horizontal-space');
|
let toolbar = document.getElementById('zotero-pane-horizontal-space');
|
||||||
let extendedToolbar = document.getElementById('zotero-item-pane-padding-top');
|
let extendedToolbar = document.getElementById('zotero-item-pane-padding-top');
|
||||||
let itemPane = document.getElementById('zotero-item-pane');
|
let itemPane = document.getElementById('zotero-item-pane');
|
||||||
|
|
||||||
|
if (prevIndex != 0) {
|
||||||
|
_pdfTabHidden = itemPane.hidden;
|
||||||
|
}
|
||||||
|
|
||||||
if (type == 'library') {
|
if (type == 'library') {
|
||||||
toolbar.hidden = false;
|
toolbar.hidden = false;
|
||||||
extendedToolbar.hidden = true;
|
extendedToolbar.hidden = true;
|
||||||
|
@ -817,27 +773,235 @@ var ZoteroItemPane = new function() {
|
||||||
else {
|
else {
|
||||||
toolbar.hidden = true;
|
toolbar.hidden = true;
|
||||||
extendedToolbar.hidden = false;
|
extendedToolbar.hidden = false;
|
||||||
|
itemPane.hidden = _pdfTabHidden;
|
||||||
|
}
|
||||||
|
|
||||||
|
let state = contextualDeck.children[contextualDeck.selectedIndex].getAttribute('state');
|
||||||
|
let mainDeck = document.getElementById('zotero-item-pane-main-deck');
|
||||||
|
document.getElementById('temp-toggle-1').firstChild.remove();
|
||||||
|
document.getElementById('temp-toggle-2').firstChild.remove();
|
||||||
|
if (state == 0) {
|
||||||
|
document.getElementById('temp-toggle-1').append('■ □');
|
||||||
|
document.getElementById('temp-toggle-2').append('■ □');
|
||||||
|
mainDeck.selectedIndex = state;
|
||||||
|
}
|
||||||
|
else if (state == 1) {
|
||||||
|
document.getElementById('temp-toggle-1').append('□ ■');
|
||||||
|
document.getElementById('temp-toggle-2').append('□ ■');
|
||||||
|
mainDeck.selectedIndex = state;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
function _updateNoteCount() {
|
this.addPDFTabContext = function (tabID, itemID) {
|
||||||
var c = _notesList.childNodes.length;
|
let contextualDeck = document.getElementById('zotero-item-pane-contextual-deck');
|
||||||
|
|
||||||
var str = 'pane.item.notes.count.';
|
let container = document.createElement('vbox');
|
||||||
switch (c){
|
container.id = tabID + '-context';
|
||||||
case 0:
|
container.className = 'zotero-item-pane-content';
|
||||||
str += 'zero';
|
contextualDeck.appendChild(container);
|
||||||
break;
|
|
||||||
case 1:
|
var item = Zotero.Items.get(itemID);
|
||||||
str += 'singular';
|
if (!item.parentID) {
|
||||||
break;
|
container.append('The PDF doesn\'t have a parent');
|
||||||
default:
|
return;
|
||||||
str += 'plural';
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
_notesLabel.value = Zotero.getString(str, [c]);
|
let parentID = item.parentID;
|
||||||
|
|
||||||
|
let mainDeck = document.getElementById('zotero-item-pane-main-deck');
|
||||||
|
let pinDeck = document.getElementById('zotero-item-pane-pin-deck2');
|
||||||
|
container.setAttribute('state', (mainDeck.selectedIndex == 1 && pinDeck.selectedIndex == 1) ? 1 : 0)
|
||||||
|
|
||||||
|
|
||||||
|
let parentItem = Zotero.Items.get(parentID);
|
||||||
|
|
||||||
|
let tabbox = document.createElement('tabbox');
|
||||||
|
tabbox.setAttribute('flex', '1');
|
||||||
|
tabbox.className = 'zotero-view-tabbox';
|
||||||
|
let tabs = document.createElement('tabs');
|
||||||
|
tabs.className = 'zotero-editpane-tabs';
|
||||||
|
|
||||||
|
container.append(tabbox);
|
||||||
|
|
||||||
|
|
||||||
|
let tabInfo = document.createElement('tab');
|
||||||
|
tabInfo.setAttribute('label', Zotero.Intl.strings['zotero.tabs.info.label']);
|
||||||
|
let tabNotes = document.createElement('tab');
|
||||||
|
tabNotes.setAttribute('label', Zotero.Intl.strings['zotero.tabs.notes.label']);
|
||||||
|
let tabTags = document.createElement('tab');
|
||||||
|
tabTags.setAttribute('label', Zotero.Intl.strings['zotero.tabs.tags.label']);
|
||||||
|
let tabRelated = document.createElement('tab');
|
||||||
|
tabRelated.setAttribute('label', Zotero.Intl.strings['zotero.tabs.related.label']);
|
||||||
|
tabs.append(tabInfo, tabNotes, tabTags, tabRelated);
|
||||||
|
|
||||||
|
let tabpanels = document.createElement('tabpanels');
|
||||||
|
tabpanels.setAttribute('flex', '1');
|
||||||
|
tabpanels.className = 'zotero-view-item';
|
||||||
|
|
||||||
|
tabbox.append(tabs, tabpanels);
|
||||||
|
|
||||||
|
let panelInfo = document.createElement('tabpanel');
|
||||||
|
panelInfo.setAttribute('flex', '1')
|
||||||
|
panelInfo.className = 'zotero-editpane-item-box';
|
||||||
|
let itemBox = document.createElement('zoteroitembox');
|
||||||
|
itemBox.setAttribute('flex', '1');
|
||||||
|
panelInfo.append(itemBox);
|
||||||
|
|
||||||
|
let panelNotes = document.createElement('tabpanel');
|
||||||
|
panelNotes.setAttribute('flex', '1');
|
||||||
|
panelNotes.setAttribute('orient', 'vertical');
|
||||||
|
|
||||||
|
var deck = document.createElement('deck');
|
||||||
|
deck.setAttribute('flex', '1');
|
||||||
|
|
||||||
|
panelNotes.append(deck);
|
||||||
|
|
||||||
|
var vbox2 = document.createElement('vbox');
|
||||||
|
|
||||||
|
|
||||||
|
let returnButton = document.createElement('toolbarbutton');
|
||||||
|
returnButton.className = 'zotero-tb-button';
|
||||||
|
returnButton.id = 'zotero-tb-return';
|
||||||
|
returnButton.style.listStyleImage = 'url(\'chrome://zotero/skin/citation-delete.png\')'
|
||||||
|
returnButton.addEventListener('click', () => {
|
||||||
|
deck.setAttribute('selectedIndex', 0);
|
||||||
|
});
|
||||||
|
|
||||||
|
var bar = document.createElement('hbox')
|
||||||
|
bar.append(returnButton, 'Child Notes');
|
||||||
|
bar.style.overflowX = 'hidden';
|
||||||
|
bar.style.textOverflow = 'ellipsis';
|
||||||
|
bar.style.fontWeight = 'bold';
|
||||||
|
|
||||||
|
let note = document.createElement('zoteronoteeditor');
|
||||||
|
|
||||||
|
note.setAttribute('flex', 1);
|
||||||
|
|
||||||
|
vbox2.append(bar, note);
|
||||||
|
|
||||||
|
|
||||||
|
var vbox = document.createElement('vbox');
|
||||||
|
vbox.setAttribute('flex', '1');
|
||||||
|
vbox.setAttribute('class', 'zotero-box');
|
||||||
|
panelNotes.append(vbox);
|
||||||
|
|
||||||
|
var hbox = document.createElement('hbox');
|
||||||
|
hbox.setAttribute('align', 'center');
|
||||||
|
|
||||||
|
var label = document.createElement('label');
|
||||||
|
var button = document.createElement('button');
|
||||||
|
button.setAttribute('label', Zotero.Intl.strings['zotero.item.add']);
|
||||||
|
button.addEventListener('click', () => {
|
||||||
|
deck.setAttribute('selectedIndex', 1);
|
||||||
|
let item = new Zotero.Item('note');
|
||||||
|
item.libraryID = parentItem.libraryID;
|
||||||
|
item.parentItemID = parentItem.id;
|
||||||
|
note.mode = 'edit';
|
||||||
|
note.item = item;
|
||||||
|
note.focus();
|
||||||
|
});
|
||||||
|
hbox.append(label, button);
|
||||||
|
|
||||||
|
var grid = document.createElement('grid');
|
||||||
|
grid.setAttribute('flex', 1);
|
||||||
|
var columns = document.createElement('columns');
|
||||||
|
var column = document.createElement('column');
|
||||||
|
column.setAttribute('flex', 1);
|
||||||
|
columns.append(column);
|
||||||
|
var column = document.createElement('column');
|
||||||
|
columns.append(column);
|
||||||
|
grid.append(columns);
|
||||||
|
var rows = document.createElement('rows');
|
||||||
|
rows.setAttribute('flex', 1);
|
||||||
|
grid.append(rows);
|
||||||
|
|
||||||
|
vbox.append(hbox, grid);
|
||||||
|
|
||||||
|
deck.append(vbox, vbox2);
|
||||||
|
|
||||||
|
deck.setAttribute('selectedIndex', 0);
|
||||||
|
deck.className = 'zotero-item-pane-content';
|
||||||
|
|
||||||
|
|
||||||
|
let panelTags = document.createElement('tabpanel');
|
||||||
|
panelTags.setAttribute('orient', 'vertical');
|
||||||
|
panelTags.setAttribute('context', 'tags-context-menu');
|
||||||
|
panelTags.className = 'tags-pane';
|
||||||
|
panelTags.style.display = 'flex';
|
||||||
|
const HTML_NS = 'http://www.w3.org/1999/xhtml';
|
||||||
|
var div = document.createElementNS(HTML_NS, 'div');
|
||||||
|
div.className = 'tags-box-container';
|
||||||
|
div.style.display = 'flex';
|
||||||
|
div.style.flexGrow = '1';
|
||||||
|
panelTags.append(div);
|
||||||
|
|
||||||
|
let panelRelated = document.createElement('tabpanel');
|
||||||
|
let relatedBox = document.createElement('relatedbox');
|
||||||
|
relatedBox.setAttribute('flex', '1');
|
||||||
|
relatedBox.className = 'zotero-editpane-related';
|
||||||
|
panelRelated.append(relatedBox);
|
||||||
|
|
||||||
|
tabpanels.append(panelInfo, panelNotes, panelTags, panelRelated);
|
||||||
|
|
||||||
|
itemBox.mode = 'edit';
|
||||||
|
itemBox.item = Zotero.Items.get(parentID);
|
||||||
|
|
||||||
|
relatedBox.mode = 'edit';
|
||||||
|
relatedBox.item = parentItem;
|
||||||
|
|
||||||
|
panelRelated.addEventListener('click', (event) => {
|
||||||
|
if (event.originalTarget.closest('.zotero-clicky')) {
|
||||||
|
Zotero_Tabs.select('zotero-pane');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
let _renderNotesPanel = () => {
|
||||||
|
while (rows.firstChild) {
|
||||||
|
rows.firstChild.remove();
|
||||||
|
}
|
||||||
|
|
||||||
|
let parentNotes = Zotero.Items.get(parentItem.getNotes());
|
||||||
|
this._appendNoteRows(parentNotes, rows, true, (id) => {
|
||||||
|
deck.setAttribute('selectedIndex', 1);
|
||||||
|
note.mode = 'edit';
|
||||||
|
note.item = Zotero.Items.get(id);
|
||||||
|
note.parentItem = null;
|
||||||
|
}, (id) => {
|
||||||
|
ZoteroItemPane.removeNote(id);
|
||||||
|
});
|
||||||
|
|
||||||
|
var c = parentNotes.length;
|
||||||
|
var str = 'pane.item.notes.count.' + (c == 0 && 'zero' || c == 1 && 'singular' || 'plural');
|
||||||
|
label.value = Zotero.getString(str, [c]);
|
||||||
|
}
|
||||||
|
|
||||||
|
_contextNoteUpdaters.push({
|
||||||
|
tabID,
|
||||||
|
callback: _renderNotesPanel
|
||||||
|
});
|
||||||
|
|
||||||
|
_renderNotesPanel();
|
||||||
|
|
||||||
|
let mode = 'edit';
|
||||||
|
|
||||||
|
let _tagsBox = { current: null };
|
||||||
|
let focusItemsList = false;
|
||||||
|
|
||||||
|
let _renderTagsPanel = () => {
|
||||||
|
ReactDOM.render(
|
||||||
|
<TagsBoxContainer
|
||||||
|
key={'tagsBox-' + parentItem.id}
|
||||||
|
item={parentItem}
|
||||||
|
editable={mode != 'view'}
|
||||||
|
ref={_tagsBox}
|
||||||
|
onResetSelection={focusItemsList}
|
||||||
|
/>,
|
||||||
|
div
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
_renderTagsPanel();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -69,23 +69,23 @@
|
||||||
<button id="zotero-item-show-original" label="Show Original"
|
<button id="zotero-item-show-original" label="Show Original"
|
||||||
oncommand="ZoteroPane_Local.showOriginalItem()" hidden="true"/>
|
oncommand="ZoteroPane_Local.showOriginalItem()" hidden="true"/>
|
||||||
|
|
||||||
<deck id="zotero-item-pane-content" selectedIndex="0" flex="1">
|
<deck id="zotero-item-pane-content" class="zotero-item-pane-content" selectedIndex="0" flex="1">
|
||||||
<!-- Center label (for zero or multiple item selection) -->
|
<!-- Center label (for zero or multiple item selection) -->
|
||||||
<groupbox id="zotero-item-pane-groupbox" pack="center" align="center">
|
<groupbox id="zotero-item-pane-groupbox" pack="center" align="center">
|
||||||
<vbox id="zotero-item-pane-message-box"/>
|
<vbox id="zotero-item-pane-message-box"/>
|
||||||
</groupbox>
|
</groupbox>
|
||||||
|
|
||||||
<!-- Regular item -->
|
<!-- Regular item -->
|
||||||
<tabbox id="zotero-view-tabbox" flex="1" onselect="if (!ZoteroPane_Local.collectionsView.selection || event.originalTarget.localName != 'tabpanels') { return; }; ZoteroItemPane.viewItem(ZoteroPane_Local.getSelectedItems()[0], ZoteroPane_Local.collectionsView.editable ? 'edit' : 'view', this.selectedIndex)">
|
<tabbox id="zotero-view-tabbox" class="zotero-view-tabbox" flex="1" onselect="if (!ZoteroPane_Local.collectionsView.selection || event.originalTarget.localName != 'tabpanels') { return; }; ZoteroItemPane.viewItem(ZoteroPane_Local.getSelectedItems()[0], ZoteroPane_Local.collectionsView.editable ? 'edit' : 'view', this.selectedIndex)">
|
||||||
<tabs id="zotero-editpane-tabs">
|
<tabs id="zotero-editpane-tabs" class="zotero-editpane-tabs">
|
||||||
<tab id="zotero-editpane-info-tab" label="&zotero.tabs.info.label;"/>
|
<tab id="zotero-editpane-info-tab" label="&zotero.tabs.info.label;"/>
|
||||||
<tab id="zotero-editpane-notes-tab" label="&zotero.tabs.notes.label;"/>
|
<tab id="zotero-editpane-notes-tab" label="&zotero.tabs.notes.label;"/>
|
||||||
<tab id="zotero-editpane-tags-tab" label="&zotero.tabs.tags.label;"/>
|
<tab id="zotero-editpane-tags-tab" label="&zotero.tabs.tags.label;"/>
|
||||||
<tab id="zotero-editpane-related-tab" label="&zotero.tabs.related.label;"/>
|
<tab id="zotero-editpane-related-tab" label="&zotero.tabs.related.label;"/>
|
||||||
</tabs>
|
</tabs>
|
||||||
<tabpanels id="zotero-view-item" flex="1">
|
<tabpanels id="zotero-view-item" class="zotero-view-item" flex="1">
|
||||||
<tabpanel>
|
<tabpanel flex="1">
|
||||||
<zoteroitembox id="zotero-editpane-item-box" flex="1"/>
|
<zoteroitembox id="zotero-editpane-item-box" class="zotero-editpane-item-box" flex="1"/>
|
||||||
</tabpanel>
|
</tabpanel>
|
||||||
|
|
||||||
<tabpanel flex="1" orient="vertical">
|
<tabpanel flex="1" orient="vertical">
|
||||||
|
@ -104,12 +104,12 @@
|
||||||
</vbox>
|
</vbox>
|
||||||
</tabpanel>
|
</tabpanel>
|
||||||
|
|
||||||
<tabpanel id="tags-pane" orient="vertical" context="tags-context-menu">
|
<tabpanel id="tags-pane" class="tags-pane" orient="vertical" context="tags-context-menu">
|
||||||
<html:div id="tags-box-container"></html:div>
|
<html:div id="tags-box-container" class="tags-box-container"></html:div>
|
||||||
</tabpanel>
|
</tabpanel>
|
||||||
|
|
||||||
<tabpanel>
|
<tabpanel>
|
||||||
<relatedbox id="zotero-editpane-related" flex="1"/>
|
<relatedbox id="zotero-editpane-related" class="zotero-editpane-related" flex="1"/>
|
||||||
</tabpanel>
|
</tabpanel>
|
||||||
</tabpanels>
|
</tabpanels>
|
||||||
</tabbox>
|
</tabbox>
|
||||||
|
@ -123,6 +123,10 @@
|
||||||
<zoteronoteeditor id="zotero-note-editor" flex="1" notitle="1"
|
<zoteronoteeditor id="zotero-note-editor" flex="1" notitle="1"
|
||||||
previousfocus="zotero-items-tree"
|
previousfocus="zotero-items-tree"
|
||||||
onerror="return;ZoteroPane.displayErrorMessage(); /*this.mode = 'view'*/"/>
|
onerror="return;ZoteroPane.displayErrorMessage(); /*this.mode = 'view'*/"/>
|
||||||
|
<!-- TODO: Localize -->
|
||||||
|
<button id="zotero-view-note-sidebar-button"
|
||||||
|
label="Edit in notes sidebar"
|
||||||
|
oncommand="ZoteroItemPane.openNoteSidebar()"/>
|
||||||
<button id="zotero-view-note-button"
|
<button id="zotero-view-note-button"
|
||||||
label="&zotero.notes.separate;"
|
label="&zotero.notes.separate;"
|
||||||
oncommand="ZoteroItemPane.openNoteWindow()"/>
|
oncommand="ZoteroItemPane.openNoteWindow()"/>
|
||||||
|
|
|
@ -233,9 +233,7 @@
|
||||||
<menuitem class="menu-type-reader" label="Even Spreads" oncommand="ZoteroStandalone.onReaderCmd('switchspreadmode_even')"/>
|
<menuitem class="menu-type-reader" label="Even Spreads" oncommand="ZoteroStandalone.onReaderCmd('switchspreadmode_even')"/>
|
||||||
<menuseparator class="menu-type-reader"/>
|
<menuseparator class="menu-type-reader"/>
|
||||||
|
|
||||||
<menu id="layout-menu"
|
<menu id="layout-menu" label="&layout.label;">
|
||||||
class="menu-type-library"
|
|
||||||
label="&layout.label;">
|
|
||||||
<menupopup oncommand="ZoteroStandalone.onViewMenuItemClick(event)">
|
<menupopup oncommand="ZoteroStandalone.onViewMenuItemClick(event)">
|
||||||
<menuitem
|
<menuitem
|
||||||
id="view-menuitem-standard"
|
id="view-menuitem-standard"
|
||||||
|
|
|
@ -113,10 +113,10 @@ var Zotero_Tabs = new function () {
|
||||||
index = index || this._tabs.length;
|
index = index || this._tabs.length;
|
||||||
this._tabs.splice(index, 0, tab);
|
this._tabs.splice(index, 0, tab);
|
||||||
this._update();
|
this._update();
|
||||||
|
Zotero.Notifier.trigger('add', 'tab', id, notifierData);
|
||||||
if (select) {
|
if (select) {
|
||||||
this.select(id);
|
this.select(id);
|
||||||
}
|
}
|
||||||
Zotero.Notifier.trigger('add', 'tab', id, notifierData);
|
|
||||||
return { id, container };
|
return { id, container };
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -165,7 +165,8 @@ class EditorInstance {
|
||||||
citationItems: [citationItem],
|
citationItems: [citationItem],
|
||||||
properties: {}
|
properties: {}
|
||||||
};
|
};
|
||||||
list.push({ annotation, citation });
|
let formattedCitation = (await this._getFormattedCitationParts(citation)).join(';');
|
||||||
|
list.push({ annotation, citation, formattedCitation });
|
||||||
}
|
}
|
||||||
return list;
|
return list;
|
||||||
}
|
}
|
||||||
|
@ -186,16 +187,18 @@ class EditorInstance {
|
||||||
if (!item) {
|
if (!item) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
list.push({
|
let citation = {
|
||||||
citation: {
|
citationItems: [{
|
||||||
citationItems: [{
|
uris: [Zotero.URI.getItemURI(item)],
|
||||||
uris: [Zotero.URI.getItemURI(item)],
|
itemData: Zotero.Cite.System.prototype.retrieveItem(item)
|
||||||
itemData: Zotero.Cite.System.prototype.retrieveItem(item),
|
}],
|
||||||
}],
|
properties: {}
|
||||||
properties: {}
|
};
|
||||||
}
|
|
||||||
});
|
let formattedCitation = (await this._getFormattedCitationParts(citation)).join(';');
|
||||||
|
|
||||||
|
list.push({ citation, formattedCitation });
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (type === 'zotero/annotation') {
|
else if (type === 'zotero/annotation') {
|
||||||
|
@ -272,6 +275,13 @@ class EditorInstance {
|
||||||
this._save(noteData);
|
this._save(noteData);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
case 'generateCitation': {
|
||||||
|
let { citation, pos } = message;
|
||||||
|
let formattedCitation = (await this._getFormattedCitationParts(citation)).join(';');
|
||||||
|
let list = [{ citation, formattedCitation }];
|
||||||
|
this._postMessage({ action: 'insertAnnotationsAndCitations', list, pos });
|
||||||
|
return;
|
||||||
|
}
|
||||||
case 'subscribeProvider': {
|
case 'subscribeProvider': {
|
||||||
let { subscription } = message;
|
let { subscription } = message;
|
||||||
this._subscriptions.push(subscription);
|
this._subscriptions.push(subscription);
|
||||||
|
@ -339,8 +349,8 @@ class EditorInstance {
|
||||||
async _feedSubscription(subscription) {
|
async _feedSubscription(subscription) {
|
||||||
let { id, type, nodeId, data } = subscription;
|
let { id, type, nodeId, data } = subscription;
|
||||||
if (type === 'citation') {
|
if (type === 'citation') {
|
||||||
let formattedCitation = await this._getFormattedCitation(data.citation);
|
let parts = await this._getFormattedCitationParts(data.citation);
|
||||||
this._postMessage({ action: 'notifyProvider', id, type, data: { formattedCitation } });
|
this._postMessage({ action: 'notifyProvider', id, type, data: { formattedCitation: parts.join(';') } });
|
||||||
}
|
}
|
||||||
else if (type === 'image') {
|
else if (type === 'image') {
|
||||||
let { attachmentKey } = data;
|
let { attachmentKey } = data;
|
||||||
|
@ -548,7 +558,7 @@ class EditorInstance {
|
||||||
return str;
|
return str;
|
||||||
}
|
}
|
||||||
|
|
||||||
async _getFormattedCitation(citation) {
|
async _getFormattedCitationParts(citation) {
|
||||||
let formattedItems = [];
|
let formattedItems = [];
|
||||||
for (let citationItem of citation.citationItems) {
|
for (let citationItem of citation.citationItems) {
|
||||||
let item = await this._getItemFromURIs(citationItem.uris);
|
let item = await this._getItemFromURIs(citationItem.uris);
|
||||||
|
@ -565,7 +575,7 @@ class EditorInstance {
|
||||||
// formattedItems.push(formattedItem);
|
// formattedItems.push(formattedItem);
|
||||||
// }
|
// }
|
||||||
}
|
}
|
||||||
return formattedItems.join(';');
|
return formattedItems;
|
||||||
}
|
}
|
||||||
|
|
||||||
_getBackupStr(item) {
|
_getBackupStr(item) {
|
||||||
|
@ -672,9 +682,11 @@ class EditorInstance {
|
||||||
citationItem.uris = [Zotero.URI.getItemURI(item)];
|
citationItem.uris = [Zotero.URI.getItemURI(item)];
|
||||||
citationItem.itemData = Zotero.Cite.System.prototype.retrieveItem(item);
|
citationItem.itemData = Zotero.Cite.System.prototype.retrieveItem(item);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
let formattedCitation = (await that._getFormattedCitationParts(citation)).join(';');
|
||||||
|
|
||||||
if (progressCallback || !citationData.citationItems.length) {
|
if (progressCallback || !citationData.citationItems.length) {
|
||||||
that._postMessage({ action: 'setCitation', nodeId, citation });
|
that._postMessage({ action: 'setCitation', nodeId, citation, formattedCitation });
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
|
@ -521,14 +521,8 @@ class ReaderTab extends ReaderInstance {
|
||||||
|
|
||||||
_toggleNoteSidebar(isToggled) {
|
_toggleNoteSidebar(isToggled) {
|
||||||
let itemPane = this._window.document.getElementById('zotero-item-pane');
|
let itemPane = this._window.document.getElementById('zotero-item-pane');
|
||||||
var noteEditor = this._window.document.getElementById('zotero-note-editor');
|
|
||||||
let item = noteEditor.item;
|
|
||||||
let zp = Zotero.getActiveZoteroPane();
|
|
||||||
if (itemPane.hidden) {
|
if (itemPane.hidden) {
|
||||||
if (item) {
|
itemPane.hidden = false;
|
||||||
zp.selectItem(item.id);
|
|
||||||
itemPane.hidden = false;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
itemPane.hidden = true;
|
itemPane.hidden = true;
|
||||||
|
|
|
@ -131,29 +131,6 @@ var ZoteroPane = new function()
|
||||||
|
|
||||||
// continue loading pane
|
// continue loading pane
|
||||||
_loadPane();
|
_loadPane();
|
||||||
|
|
||||||
Zotero_Tabs.onTabSelect = (id, type) => {
|
|
||||||
let toolbar = document.getElementById('zotero-pane-horizontal-space');
|
|
||||||
let extendedToolbar = document.getElementById('zotero-item-pane-padding-top');
|
|
||||||
let itemPane = document.getElementById('zotero-item-pane');
|
|
||||||
if (type == 'library') {
|
|
||||||
toolbar.hidden = false;
|
|
||||||
extendedToolbar.hidden = true;
|
|
||||||
itemPane.hidden = false;
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
toolbar.hidden = true;
|
|
||||||
extendedToolbar.hidden = false;
|
|
||||||
let items = ZoteroPane_Local.itemsView.getSelectedItems();
|
|
||||||
|
|
||||||
if (items.length == 1 && items[0].isNote()) {
|
|
||||||
itemPane.hidden = false;
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
itemPane.hidden = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1222,6 +1199,8 @@ var ZoteroPane = new function()
|
||||||
// Rename tab
|
// Rename tab
|
||||||
Zotero_Tabs.rename('zotero-pane', collectionTreeRow.getName());
|
Zotero_Tabs.rename('zotero-pane', collectionTreeRow.getName());
|
||||||
|
|
||||||
|
ZoteroItemPane.updateStandaloneNotesList(true);
|
||||||
|
|
||||||
// Clear quick search and tag selector when switching views
|
// Clear quick search and tag selector when switching views
|
||||||
document.getElementById('zotero-tb-search').value = "";
|
document.getElementById('zotero-tb-search').value = "";
|
||||||
if (ZoteroPane.tagSelector) {
|
if (ZoteroPane.tagSelector) {
|
||||||
|
@ -1421,8 +1400,6 @@ var ZoteroPane = new function()
|
||||||
}
|
}
|
||||||
_lastSelectedItems = ids;
|
_lastSelectedItems = ids;
|
||||||
|
|
||||||
ZoteroItemPane.togglePane(true);
|
|
||||||
|
|
||||||
var tabs = document.getElementById('zotero-view-tabbox');
|
var tabs = document.getElementById('zotero-view-tabbox');
|
||||||
|
|
||||||
// save note when switching from a note
|
// save note when switching from a note
|
||||||
|
@ -4074,8 +4051,7 @@ var ZoteroPane = new function()
|
||||||
if (!this.collectionsView.editable) {
|
if (!this.collectionsView.editable) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
ZoteroItemPane.pinNote(item.id);
|
document.getElementById('zotero-view-note-button').doCommand();
|
||||||
// document.getElementById('zotero-view-note-button').doCommand();
|
|
||||||
}
|
}
|
||||||
else if (item.isAttachment()) {
|
else if (item.isAttachment()) {
|
||||||
yield this.viewAttachment(item.id, event);
|
yield this.viewAttachment(item.id, event);
|
||||||
|
@ -4266,7 +4242,7 @@ var ZoteroPane = new function()
|
||||||
|
|
||||||
Zotero.debug("Opening " + path);
|
Zotero.debug("Opening " + path);
|
||||||
Zotero.Notifier.trigger('open', 'file', item.id);
|
Zotero.Notifier.trigger('open', 'file', item.id);
|
||||||
launchFile(path, item.attachmentContentType);
|
launchFile(path, item.attachmentContentType, item.id);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -5219,6 +5195,8 @@ var ZoteroPane = new function()
|
||||||
|
|
||||||
// Allow item pane to shrink to available height in stacked mode, but don't expand to be too
|
// Allow item pane to shrink to available height in stacked mode, but don't expand to be too
|
||||||
// wide when there's no persisted width in non-stacked mode
|
// wide when there's no persisted width in non-stacked mode
|
||||||
|
|
||||||
|
// TODO: Fix this together with stacked view
|
||||||
itemPane.setAttribute("flex", stackedLayout ? 1 : 0);
|
itemPane.setAttribute("flex", stackedLayout ? 1 : 0);
|
||||||
|
|
||||||
this.handleTagSelectorResize();
|
this.handleTagSelectorResize();
|
||||||
|
@ -5232,6 +5210,8 @@ var ZoteroPane = new function()
|
||||||
* Revisit when we're all HTML.
|
* Revisit when we're all HTML.
|
||||||
*/
|
*/
|
||||||
this.updateTagsBoxSize = function () {
|
this.updateTagsBoxSize = function () {
|
||||||
|
// TODO: We can probably remove this function
|
||||||
|
return;
|
||||||
var pane = document.querySelector('#zotero-item-pane');
|
var pane = document.querySelector('#zotero-item-pane');
|
||||||
var header = document.querySelector('#zotero-item-pane .tags-box-header');
|
var header = document.querySelector('#zotero-item-pane .tags-box-header');
|
||||||
var list = document.querySelector('#zotero-item-pane .tags-box-list');
|
var list = document.querySelector('#zotero-item-pane .tags-box-list');
|
||||||
|
|
|
@ -227,7 +227,7 @@
|
||||||
</vbox>
|
</vbox>
|
||||||
</vbox>
|
</vbox>
|
||||||
|
|
||||||
<hbox flex="1">
|
<box id="zotero-layout-switcher" orient="horizontal" zotero-persist="orient" flex="1">
|
||||||
<deck flex="1" id="tabs-deck">
|
<deck flex="1" id="tabs-deck">
|
||||||
<vbox id="zotero-pane"
|
<vbox id="zotero-pane"
|
||||||
onkeydown="ZoteroPane_Local.handleKeyDown(event, this.id)"
|
onkeydown="ZoteroPane_Local.handleKeyDown(event, this.id)"
|
||||||
|
@ -358,11 +358,10 @@
|
||||||
<grippy id="zotero-collections-grippy"/>
|
<grippy id="zotero-collections-grippy"/>
|
||||||
</splitter>
|
</splitter>
|
||||||
|
|
||||||
<box id="zotero-layout-switcher" orient="horizontal" zotero-persist="orient" flex="1">
|
<vbox id="zotero-items-pane" zotero-persist="width height" flex="1">
|
||||||
<vbox id="zotero-items-pane" zotero-persist="width height" flex="1">
|
<deck id="zotero-items-pane-content" selectedIndex="0" flex="1">
|
||||||
<deck id="zotero-items-pane-content" selectedIndex="0" flex="1">
|
<!-- Key navigation is handled by listener in itemTreeView.js -->
|
||||||
<!-- Key navigation is handled by listener in itemTreeView.js -->
|
<tree
|
||||||
<tree
|
|
||||||
id="zotero-items-tree"
|
id="zotero-items-tree"
|
||||||
enableColumnDrag="true"
|
enableColumnDrag="true"
|
||||||
disableKeyNavigation="true"
|
disableKeyNavigation="true"
|
||||||
|
@ -374,200 +373,231 @@
|
||||||
flex="1"
|
flex="1"
|
||||||
hidden="true"
|
hidden="true"
|
||||||
zotero-persist="current-view-group">
|
zotero-persist="current-view-group">
|
||||||
<treecols id="zotero-items-columns-header">
|
<treecols id="zotero-items-columns-header">
|
||||||
<treecol
|
<treecol
|
||||||
id="zotero-items-column-title" primary="true" default-in="default feed"
|
id="zotero-items-column-title" primary="true"
|
||||||
|
default-in="default feed"
|
||||||
label="&zotero.items.title_column;" ignoreincolumnpicker="true"
|
label="&zotero.items.title_column;" ignoreincolumnpicker="true"
|
||||||
flex="4" zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
flex="4"
|
||||||
<splitter class="tree-splitter"/>
|
zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
||||||
<treecol
|
<splitter class="tree-splitter"/>
|
||||||
|
<treecol
|
||||||
id="zotero-items-column-firstCreator" default-in="default feed"
|
id="zotero-items-column-firstCreator" default-in="default feed"
|
||||||
label="&zotero.items.creator_column;"
|
label="&zotero.items.creator_column;"
|
||||||
flex="1" zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
flex="1"
|
||||||
<splitter class="tree-splitter"/>
|
zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
||||||
<treecol
|
<splitter class="tree-splitter"/>
|
||||||
|
<treecol
|
||||||
id="zotero-items-column-itemType"
|
id="zotero-items-column-itemType"
|
||||||
label="&zotero.items.type_column;"
|
label="&zotero.items.type_column;"
|
||||||
width="40" zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
width="40"
|
||||||
<splitter class="tree-splitter"/>
|
zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
||||||
<treecol
|
<splitter class="tree-splitter"/>
|
||||||
|
<treecol
|
||||||
id="zotero-items-column-date" default-in="feed"
|
id="zotero-items-column-date" default-in="feed"
|
||||||
label="&zotero.items.date_column;"
|
label="&zotero.items.date_column;"
|
||||||
flex="1" zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
flex="1"
|
||||||
<splitter class="tree-splitter"/>
|
zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
||||||
<treecol
|
<splitter class="tree-splitter"/>
|
||||||
|
<treecol
|
||||||
id="zotero-items-column-year" disabled-in="feed"
|
id="zotero-items-column-year" disabled-in="feed"
|
||||||
label="&zotero.items.year_column;"
|
label="&zotero.items.year_column;"
|
||||||
flex="1" zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
flex="1"
|
||||||
<splitter class="tree-splitter"/>
|
zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
||||||
<treecol
|
<splitter class="tree-splitter"/>
|
||||||
|
<treecol
|
||||||
id="zotero-items-column-publisher"
|
id="zotero-items-column-publisher"
|
||||||
label="&zotero.items.publisher_column;"
|
label="&zotero.items.publisher_column;"
|
||||||
flex="1" zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
flex="1"
|
||||||
<splitter class="tree-splitter"/>
|
zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
||||||
<treecol
|
<splitter class="tree-splitter"/>
|
||||||
|
<treecol
|
||||||
id="zotero-items-column-publicationTitle" disabled-in="feed"
|
id="zotero-items-column-publicationTitle" disabled-in="feed"
|
||||||
label="&zotero.items.publication_column;"
|
label="&zotero.items.publication_column;"
|
||||||
flex="1" zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
flex="1"
|
||||||
<splitter class="tree-splitter"/>
|
zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
||||||
<treecol
|
<splitter class="tree-splitter"/>
|
||||||
|
<treecol
|
||||||
id="zotero-items-column-journalAbbreviation" disabled-in="feed"
|
id="zotero-items-column-journalAbbreviation" disabled-in="feed"
|
||||||
submenu="true"
|
submenu="true"
|
||||||
label="&zotero.items.journalAbbr_column;"
|
label="&zotero.items.journalAbbr_column;"
|
||||||
flex="1" zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
flex="1"
|
||||||
<splitter class="tree-splitter"/>
|
zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
||||||
<treecol
|
<splitter class="tree-splitter"/>
|
||||||
|
<treecol
|
||||||
id="zotero-items-column-language"
|
id="zotero-items-column-language"
|
||||||
submenu="true"
|
submenu="true"
|
||||||
label="&zotero.items.language_column;"
|
label="&zotero.items.language_column;"
|
||||||
flex="1" zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
flex="1"
|
||||||
<splitter class="tree-splitter"/>
|
zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
||||||
<treecol
|
<splitter class="tree-splitter"/>
|
||||||
|
<treecol
|
||||||
id="zotero-items-column-accessDate" disabled-in="feed"
|
id="zotero-items-column-accessDate" disabled-in="feed"
|
||||||
submenu="true"
|
submenu="true"
|
||||||
label="&zotero.items.accessDate_column;"
|
label="&zotero.items.accessDate_column;"
|
||||||
flex="1" zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
flex="1"
|
||||||
<splitter class="tree-splitter"/>
|
zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
||||||
<treecol
|
<splitter class="tree-splitter"/>
|
||||||
|
<treecol
|
||||||
id="zotero-items-column-libraryCatalog" disabled-in="feed"
|
id="zotero-items-column-libraryCatalog" disabled-in="feed"
|
||||||
submenu="true"
|
submenu="true"
|
||||||
label="&zotero.items.libraryCatalog_column;"
|
label="&zotero.items.libraryCatalog_column;"
|
||||||
flex="1" zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
flex="1"
|
||||||
<splitter class="tree-splitter"/>
|
zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
||||||
<treecol
|
<splitter class="tree-splitter"/>
|
||||||
|
<treecol
|
||||||
id="zotero-items-column-callNumber" disabled-in="feed"
|
id="zotero-items-column-callNumber" disabled-in="feed"
|
||||||
submenu="true"
|
submenu="true"
|
||||||
label="&zotero.items.callNumber_column;"
|
label="&zotero.items.callNumber_column;"
|
||||||
flex="1" zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
flex="1"
|
||||||
<splitter class="tree-splitter"/>
|
zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
||||||
<treecol
|
<splitter class="tree-splitter"/>
|
||||||
|
<treecol
|
||||||
id="zotero-items-column-rights"
|
id="zotero-items-column-rights"
|
||||||
submenu="true"
|
submenu="true"
|
||||||
label="&zotero.items.rights_column;"
|
label="&zotero.items.rights_column;"
|
||||||
flex="1" zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
flex="1"
|
||||||
<splitter class="tree-splitter"/>
|
zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
||||||
<treecol
|
<splitter class="tree-splitter"/>
|
||||||
|
<treecol
|
||||||
id="zotero-items-column-dateAdded" disabled-in="feed"
|
id="zotero-items-column-dateAdded" disabled-in="feed"
|
||||||
label="&zotero.items.dateAdded_column;"
|
label="&zotero.items.dateAdded_column;"
|
||||||
flex="1" zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
flex="1"
|
||||||
<splitter class="tree-splitter"/>
|
zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
||||||
<treecol
|
<splitter class="tree-splitter"/>
|
||||||
|
<treecol
|
||||||
id="zotero-items-column-dateModified" disabled-in="feed"
|
id="zotero-items-column-dateModified" disabled-in="feed"
|
||||||
label="&zotero.items.dateModified_column;"
|
label="&zotero.items.dateModified_column;"
|
||||||
flex="1" zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
flex="1"
|
||||||
<splitter class="tree-splitter"/>
|
zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
||||||
<treecol
|
<splitter class="tree-splitter"/>
|
||||||
|
<treecol
|
||||||
id="zotero-items-column-archive" disabled-in="feed"
|
id="zotero-items-column-archive" disabled-in="feed"
|
||||||
submenu="true"
|
submenu="true"
|
||||||
label="&zotero.items.archive_column;"
|
label="&zotero.items.archive_column;"
|
||||||
flex="1" zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
flex="1"
|
||||||
<splitter class="tree-splitter"/>
|
zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
||||||
<treecol
|
<splitter class="tree-splitter"/>
|
||||||
|
<treecol
|
||||||
id="zotero-items-column-archiveLocation" disabled-in="feed"
|
id="zotero-items-column-archiveLocation" disabled-in="feed"
|
||||||
submenu="true"
|
submenu="true"
|
||||||
label="&zotero.items.archiveLocation_column;"
|
label="&zotero.items.archiveLocation_column;"
|
||||||
flex="1" zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
flex="1"
|
||||||
<splitter class="tree-splitter"/>
|
zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
||||||
<treecol
|
<splitter class="tree-splitter"/>
|
||||||
|
<treecol
|
||||||
id="zotero-items-column-place" disabled-in="feed"
|
id="zotero-items-column-place" disabled-in="feed"
|
||||||
submenu="true"
|
submenu="true"
|
||||||
label="&zotero.items.place_column;"
|
label="&zotero.items.place_column;"
|
||||||
flex="1" zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
flex="1"
|
||||||
<splitter class="tree-splitter"/>
|
zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
||||||
<treecol
|
<splitter class="tree-splitter"/>
|
||||||
|
<treecol
|
||||||
id="zotero-items-column-volume" disabled-in="feed"
|
id="zotero-items-column-volume" disabled-in="feed"
|
||||||
submenu="true"
|
submenu="true"
|
||||||
label="&zotero.items.volume_column;"
|
label="&zotero.items.volume_column;"
|
||||||
flex="1" zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
flex="1"
|
||||||
<splitter class="tree-splitter"/>
|
zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
||||||
<treecol
|
<splitter class="tree-splitter"/>
|
||||||
|
<treecol
|
||||||
id="zotero-items-column-edition" disabled-in="feed"
|
id="zotero-items-column-edition" disabled-in="feed"
|
||||||
submenu="true"
|
submenu="true"
|
||||||
label="&zotero.items.edition_column;"
|
label="&zotero.items.edition_column;"
|
||||||
flex="1" zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
flex="1"
|
||||||
<splitter class="tree-splitter"/>
|
zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
||||||
<treecol
|
<splitter class="tree-splitter"/>
|
||||||
|
<treecol
|
||||||
id="zotero-items-column-pages" disabled-in="feed"
|
id="zotero-items-column-pages" disabled-in="feed"
|
||||||
submenu="true"
|
submenu="true"
|
||||||
label="&zotero.items.pages_column;"
|
label="&zotero.items.pages_column;"
|
||||||
flex="1" zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
flex="1"
|
||||||
<splitter class="tree-splitter"/>
|
zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
||||||
<treecol
|
<splitter class="tree-splitter"/>
|
||||||
|
<treecol
|
||||||
id="zotero-items-column-issue" disabled-in="feed"
|
id="zotero-items-column-issue" disabled-in="feed"
|
||||||
submenu="true"
|
submenu="true"
|
||||||
label="&zotero.items.issue_column;"
|
label="&zotero.items.issue_column;"
|
||||||
flex="1" zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
flex="1"
|
||||||
<splitter class="tree-splitter"/>
|
zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
||||||
<treecol
|
<splitter class="tree-splitter"/>
|
||||||
|
<treecol
|
||||||
id="zotero-items-column-series" disabled-in="feed"
|
id="zotero-items-column-series" disabled-in="feed"
|
||||||
submenu="true"
|
submenu="true"
|
||||||
label="&zotero.items.series_column;"
|
label="&zotero.items.series_column;"
|
||||||
flex="1" zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
flex="1"
|
||||||
<splitter class="tree-splitter"/>
|
zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
||||||
<treecol
|
<splitter class="tree-splitter"/>
|
||||||
|
<treecol
|
||||||
id="zotero-items-column-seriesTitle" disabled-in="feed"
|
id="zotero-items-column-seriesTitle" disabled-in="feed"
|
||||||
submenu="true"
|
submenu="true"
|
||||||
label="&zotero.items.seriesTitle_column;"
|
label="&zotero.items.seriesTitle_column;"
|
||||||
flex="1" zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
flex="1"
|
||||||
<splitter class="tree-splitter"/>
|
zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
||||||
<treecol
|
<splitter class="tree-splitter"/>
|
||||||
|
<treecol
|
||||||
id="zotero-items-column-court" disabled-in="feed"
|
id="zotero-items-column-court" disabled-in="feed"
|
||||||
submenu="true"
|
submenu="true"
|
||||||
label="&zotero.items.court_column;"
|
label="&zotero.items.court_column;"
|
||||||
flex="1" zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
flex="1"
|
||||||
<splitter class="tree-splitter"/>
|
zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
||||||
<treecol
|
<splitter class="tree-splitter"/>
|
||||||
|
<treecol
|
||||||
id="zotero-items-column-medium" disabled-in="feed"
|
id="zotero-items-column-medium" disabled-in="feed"
|
||||||
submenu="true"
|
submenu="true"
|
||||||
label="&zotero.items.medium_column;"
|
label="&zotero.items.medium_column;"
|
||||||
flex="1" zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
flex="1"
|
||||||
<splitter class="tree-splitter"/>
|
zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
||||||
<treecol
|
<splitter class="tree-splitter"/>
|
||||||
|
<treecol
|
||||||
id="zotero-items-column-genre" disabled-in="feed"
|
id="zotero-items-column-genre" disabled-in="feed"
|
||||||
submenu="true"
|
submenu="true"
|
||||||
label="&zotero.items.genre_column;"
|
label="&zotero.items.genre_column;"
|
||||||
flex="1" zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
flex="1"
|
||||||
<splitter class="tree-splitter"/>
|
zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
||||||
<treecol
|
<splitter class="tree-splitter"/>
|
||||||
|
<treecol
|
||||||
id="zotero-items-column-system" disabled-in="feed"
|
id="zotero-items-column-system" disabled-in="feed"
|
||||||
submenu="true"
|
submenu="true"
|
||||||
label="&zotero.items.system_column;"
|
label="&zotero.items.system_column;"
|
||||||
flex="1" zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
flex="1"
|
||||||
<splitter class="tree-splitter"/>
|
zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
||||||
<treecol
|
<splitter class="tree-splitter"/>
|
||||||
|
<treecol
|
||||||
id="zotero-items-column-extra" disabled-in="feed"
|
id="zotero-items-column-extra" disabled-in="feed"
|
||||||
label="&zotero.items.extra_column;"
|
label="&zotero.items.extra_column;"
|
||||||
flex="1" zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
flex="1"
|
||||||
<splitter class="tree-splitter"/>
|
zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
||||||
<treecol
|
<splitter class="tree-splitter"/>
|
||||||
id="zotero-items-column-hasAttachment" default-in="default" disabled-in="feed"
|
<treecol
|
||||||
|
id="zotero-items-column-hasAttachment" default-in="default"
|
||||||
|
disabled-in="feed"
|
||||||
class="treecol-image"
|
class="treecol-image"
|
||||||
label="&zotero.tabs.attachments.label;"
|
label="&zotero.tabs.attachments.label;"
|
||||||
fixed="true"
|
fixed="true"
|
||||||
zotero-persist="ordinal hidden sortActive sortDirection"/>
|
zotero-persist="ordinal hidden sortActive sortDirection"/>
|
||||||
<splitter class="tree-splitter"/>
|
<splitter class="tree-splitter"/>
|
||||||
<treecol
|
<treecol
|
||||||
id="zotero-items-column-numNotes" disabled-in="feed"
|
id="zotero-items-column-numNotes" disabled-in="feed"
|
||||||
class="treecol-image"
|
class="treecol-image"
|
||||||
label="&zotero.tabs.notes.label;"
|
label="&zotero.tabs.notes.label;"
|
||||||
zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
zotero-persist="width ordinal hidden sortActive sortDirection"/>
|
||||||
</treecols>
|
</treecols>
|
||||||
<treechildren ondragstart="ZoteroPane_Local.itemsView.onDragStart(event)"
|
<treechildren ondragstart="ZoteroPane_Local.itemsView.onDragStart(event)"
|
||||||
ondragenter="return ZoteroPane_Local.itemsView.onDragEnter(event)"
|
ondragenter="return ZoteroPane_Local.itemsView.onDragEnter(event)"
|
||||||
ondragover="return ZoteroPane_Local.itemsView.onDragOver(event)"
|
ondragover="return ZoteroPane_Local.itemsView.onDragOver(event)"
|
||||||
ondrop="return ZoteroPane_Local.itemsView.onDrop(event)"
|
ondrop="return ZoteroPane_Local.itemsView.onDrop(event)"
|
||||||
ondragend="ZoteroPane_Local.itemsView.onDragEnd(event)"/>
|
ondragend="ZoteroPane_Local.itemsView.onDragEnd(event)"/>
|
||||||
</tree>
|
</tree>
|
||||||
|
|
||||||
<!-- Label for displaying messages when items pane is hidden
|
<!-- Label for displaying messages when items pane is hidden
|
||||||
(e.g. "Advanced search mode — press Enter to search.")-->
|
(e.g. "Advanced search mode — press Enter to search.")-->
|
||||||
<vbox id="zotero-items-pane-message-box" pack="center" align="center"
|
<vbox id="zotero-items-pane-message-box" pack="center" align="center"
|
||||||
ondragenter="return ZoteroPane.itemsView.onDragEnter(event)"
|
ondragenter="return ZoteroPane.itemsView.onDragEnter(event)"
|
||||||
ondragover="return ZoteroPane.itemsView.onDragOver(event)"
|
ondragover="return ZoteroPane.itemsView.onDragOver(event)"
|
||||||
ondrop="ZoteroPane.itemsView.onDrop(event); ZoteroPane.itemsView.drop(-1, -1, event.dataTransfer)"/>
|
ondrop="ZoteroPane.itemsView.onDrop(event); ZoteroPane.itemsView.drop(-1, -1, event.dataTransfer)"/>
|
||||||
</deck>
|
</deck>
|
||||||
</vbox>
|
</vbox>
|
||||||
</box>
|
|
||||||
</hbox>
|
</hbox>
|
||||||
</vbox>
|
</vbox>
|
||||||
</deck>
|
</deck>
|
||||||
|
@ -579,8 +609,8 @@
|
||||||
</splitter>
|
</splitter>
|
||||||
|
|
||||||
<!-- itemPane.xul -->
|
<!-- itemPane.xul -->
|
||||||
<vbox id="zotero-item-pane" flex="1"/>
|
<vbox id="zotero-item-pane"/>
|
||||||
</hbox>
|
</box>
|
||||||
</vbox>
|
</vbox>
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -2,44 +2,44 @@
|
||||||
padding: 0 2em;
|
padding: 0 2em;
|
||||||
}
|
}
|
||||||
|
|
||||||
#zotero-view-tabbox, #zotero-item-pane-content > groupbox, #zotero-item-pane-content > groupbox > .groupbox-body
|
.zotero-view-tabbox, .zotero-item-pane-content > groupbox, .zotero-item-pane-content > groupbox > .groupbox-body
|
||||||
{
|
{
|
||||||
margin: 0 !important;
|
margin: 0 !important;
|
||||||
padding: 0 !important;
|
padding: 0 !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
#zotero-view-tabbox tabs tab
|
.zotero-view-tabbox tabs tab
|
||||||
{
|
{
|
||||||
margin-top: 0 !important;
|
margin-top: 0 !important;
|
||||||
margin-bottom: 0 !important;
|
margin-bottom: 0 !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
#zotero-view-tabbox tabs tab .tab-text
|
.zotero-view-tabbox tabs tab .tab-text
|
||||||
{
|
{
|
||||||
margin-top: .2em !important;
|
margin-top: .2em !important;
|
||||||
margin-bottom: .25em !important;
|
margin-bottom: .25em !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
#zotero-view-item
|
.zotero-view-item
|
||||||
{
|
{
|
||||||
padding: 0;
|
padding: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#zotero-view-item.no-tabs
|
.zotero-view-item.no-tabs
|
||||||
{
|
{
|
||||||
margin-top: 0;
|
margin-top: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#zotero-view-item > tabpanel > *
|
.zotero-view-item > tabpanel > *
|
||||||
{
|
{
|
||||||
overflow: auto;
|
overflow: auto;
|
||||||
}
|
}
|
||||||
|
|
||||||
#zotero-view-item:not([selectedIndex="0"]) > tabpanel > * {
|
.zotero-view-item:not([selectedIndex="0"]) > tabpanel > * {
|
||||||
padding-top: .25em;
|
padding-top: .25em;
|
||||||
}
|
}
|
||||||
|
|
||||||
#zotero-view-item > vbox
|
.zotero-view-item > vbox
|
||||||
{
|
{
|
||||||
overflow: auto;
|
overflow: auto;
|
||||||
margin-left: 5px;
|
margin-left: 5px;
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
Subproject commit 3d949e7c83a19af8afdd1de0fdb3f95dde4f4dea
|
Subproject commit 1da855a9e2447ff0a1409401bc2ba87f9b307038
|
|
@ -26,6 +26,7 @@
|
||||||
@import "components/editable";
|
@import "components/editable";
|
||||||
@import "components/icons";
|
@import "components/icons";
|
||||||
@import "components/mainWindow";
|
@import "components/mainWindow";
|
||||||
|
@import "components/notesList";
|
||||||
@import "components/progressMeter";
|
@import "components/progressMeter";
|
||||||
@import "components/search";
|
@import "components/search";
|
||||||
@import "components/syncButtonTooltip";
|
@import "components/syncButtonTooltip";
|
||||||
|
|
53
scss/components/_notesList.scss
Normal file
53
scss/components/_notesList.scss
Normal file
|
@ -0,0 +1,53 @@
|
||||||
|
.notes-list-container {
|
||||||
|
display: flex;
|
||||||
|
width: 100%;
|
||||||
|
overflow-y: auto;
|
||||||
|
flex-grow: 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
.notes-list {
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
height: 0;
|
||||||
|
flex-grow: 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
.note-row {
|
||||||
|
padding: 8px 0;
|
||||||
|
|
||||||
|
&:not(:last-child) {
|
||||||
|
border-bottom: 1px solid $shade-3;
|
||||||
|
}
|
||||||
|
|
||||||
|
.inner {
|
||||||
|
.first-line {
|
||||||
|
display: flex;
|
||||||
|
|
||||||
|
.title {
|
||||||
|
flex-grow: 1;
|
||||||
|
width: 0;
|
||||||
|
white-space: nowrap;
|
||||||
|
overflow: hidden;
|
||||||
|
text-overflow: ellipsis;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.second-line {
|
||||||
|
display: flex;
|
||||||
|
|
||||||
|
.date {
|
||||||
|
}
|
||||||
|
|
||||||
|
.body {
|
||||||
|
flex-grow: 1;
|
||||||
|
width: 0;
|
||||||
|
white-space: nowrap;
|
||||||
|
overflow: hidden;
|
||||||
|
text-overflow: ellipsis;
|
||||||
|
margin-left: 10px;
|
||||||
|
color: $shade-6;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,8 +1,8 @@
|
||||||
#tags-pane {
|
.tags-pane {
|
||||||
display: flex;
|
display: flex;
|
||||||
}
|
}
|
||||||
|
|
||||||
#tags-box-container {
|
.tags-box-container {
|
||||||
flex-grow: 1;
|
flex-grow: 1;
|
||||||
display: flex;
|
display: flex;
|
||||||
}
|
}
|
||||||
|
@ -14,7 +14,11 @@
|
||||||
$li-side-margin: 6px;
|
$li-side-margin: 6px;
|
||||||
|
|
||||||
flex-grow: 1;
|
flex-grow: 1;
|
||||||
width: 330px;
|
//width: 330px;
|
||||||
|
|
||||||
|
// This is necessary for XUL layout to prevent children
|
||||||
|
// container to force its height for the parent
|
||||||
|
height: 0;
|
||||||
|
|
||||||
.tags-box-header {
|
.tags-box-header {
|
||||||
display: flex;
|
display: flex;
|
||||||
|
@ -61,7 +65,7 @@
|
||||||
.editable-container {
|
.editable-container {
|
||||||
flex-grow: 1;
|
flex-grow: 1;
|
||||||
margin: 0 2px;
|
margin: 0 2px;
|
||||||
width: $item-pane-width - $icon-width - $delete-button-width - ($li-side-margin * 2);
|
//width: $item-pane-width - $icon-width - $delete-button-width - ($li-side-margin * 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
ul.tags-box-list > li:not(.multiline) .editable-container {
|
ul.tags-box-list > li:not(.multiline) .editable-container {
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
Subproject commit 156459aaf4dbba9dc91b10a4e8ecb1142e56484b
|
Subproject commit f4374cdb6386ba5cdd818ff6e3ece74aae83b394
|
Loading…
Reference in a new issue