mirror of
http://git.whoc.org.uk/git/password-manager.git
synced 2025-01-09 23:10:03 +01:00
Added HTML native support for auto-completion in tag editor
Not sure on which browser this feature is working; only tested in Chrome for Mac.
This commit is contained in:
parent
03ce1d3497
commit
2368d471e8
@ -25,6 +25,10 @@ Clipperz.Base.module('Clipperz.PM.UI.Components.Cards');
|
||||
|
||||
Clipperz.PM.UI.Components.Cards.Detail = React.createClass({
|
||||
|
||||
propTypes: {
|
||||
'allTags': React.PropTypes.array,
|
||||
},
|
||||
|
||||
viewComponentProps: function () {
|
||||
var result;
|
||||
|
||||
|
@ -29,6 +29,7 @@ Clipperz.PM.UI.Components.Cards.Edit = React.createClass({
|
||||
//============================================================================
|
||||
|
||||
propTypes: {
|
||||
'allTags': React.PropTypes.array,
|
||||
// 'label': React.PropTypes.string /*.isRequired */ ,
|
||||
// 'loading': React.PropTypes.bool,
|
||||
},
|
||||
@ -264,13 +265,12 @@ console.log("DROP"); //, anEvent);
|
||||
|
||||
//............................................................................
|
||||
|
||||
renderTags: function (someTags) {
|
||||
var tags;
|
||||
var allTags;
|
||||
cleanupTags: function (someTags) {
|
||||
return MochiKit.Base.filter(Clipperz.PM.DataModel.Record.isRegularTag, someTags).sort(Clipperz.Base.caseInsensitiveCompare);
|
||||
},
|
||||
|
||||
tags = MochiKit.Base.filter(Clipperz.PM.DataModel.Record.isRegularTag, someTags).sort(Clipperz.Base.caseInsensitiveCompare);
|
||||
allTags = tags;
|
||||
return Clipperz.PM.UI.Components.Cards.TagEditor({'selectedTags':tags, 'allTags':allTags, 'readOnly':false });
|
||||
renderTags: function (someTags) {
|
||||
return Clipperz.PM.UI.Components.Cards.TagEditor({'selectedTags':this.cleanupTags(someTags), 'allTags':this.cleanupTags(this.props['allTags']), 'readOnly':false });
|
||||
},
|
||||
|
||||
//............................................................................
|
||||
|
@ -43,10 +43,14 @@ Clipperz.PM.UI.Components.Cards.TagEditor = React.createClass({
|
||||
|
||||
//----------------------------------------------------------------------------
|
||||
|
||||
stillNotUsedTags: function () {
|
||||
// return MochiKit.Base.filter(function, this.props['allTags']);
|
||||
listOfTagsNotUsedYet: function () {
|
||||
var selectedTags = this.props['selectedTags'];
|
||||
//console.log("ALL TAGS", this.props['allTags']);
|
||||
//console.log("SELECTED TAGS", this.props['selectedTags']);
|
||||
return MochiKit.Base.filter(function (aTag) { return selectedTags.indexOf(aTag) == -1 }, this.props['allTags']);
|
||||
// return this.props['allTags'];
|
||||
},
|
||||
|
||||
|
||||
//----------------------------------------------------------------------------
|
||||
|
||||
removeTagHandler: function (anEvent) {
|
||||
@ -67,24 +71,23 @@ Clipperz.PM.UI.Components.Cards.TagEditor = React.createClass({
|
||||
|
||||
//----------------------------------------------------------------------------
|
||||
|
||||
addTagValue: function (anEvent) {
|
||||
this.addTag(anEvent.currentTarget.value);
|
||||
anEvent.currentTarget.value = "";
|
||||
},
|
||||
|
||||
handleKeyDown: function(anEvent) {
|
||||
switch (anEvent.keyCode) {
|
||||
|
||||
case 9: // tab
|
||||
console.log("TAB");
|
||||
// if (anEvent.shiftKey || !this.state.isOpen) {
|
||||
// return;
|
||||
// }
|
||||
// this.selectFocusedOption();
|
||||
break;
|
||||
this.addTagValue(anEvent);
|
||||
break;
|
||||
|
||||
case 13: // enter
|
||||
console.log("ENTER");
|
||||
this.addTag(anEvent.currentTarget.value);
|
||||
anEvent.currentTarget.value = "";
|
||||
// this.selectFocusedOption();
|
||||
break;
|
||||
|
||||
this.addTagValue(anEvent);
|
||||
anEvent.preventDefault();
|
||||
break;
|
||||
/*
|
||||
case 27: // escape
|
||||
console.log("ESCAPE");
|
||||
// if (this.state.isOpen) {
|
||||
@ -92,22 +95,22 @@ Clipperz.PM.UI.Components.Cards.TagEditor = React.createClass({
|
||||
// } else {
|
||||
// this.clearValue();
|
||||
// }
|
||||
break;
|
||||
break;
|
||||
|
||||
case 38: // up
|
||||
console.log("UP");
|
||||
// this.focusPreviousOption();
|
||||
break;
|
||||
break;
|
||||
|
||||
case 40: // down
|
||||
console.log("DOWN");
|
||||
// this.focusNextOption();
|
||||
break;
|
||||
break;
|
||||
|
||||
default: return;
|
||||
default:
|
||||
return;
|
||||
*/
|
||||
}
|
||||
|
||||
anEvent.preventDefault();
|
||||
},
|
||||
|
||||
//----------------------------------------------------------------------------
|
||||
@ -120,7 +123,10 @@ Clipperz.PM.UI.Components.Cards.TagEditor = React.createClass({
|
||||
},
|
||||
|
||||
renderEditField: function () {
|
||||
return React.DOM.input({'type':'text', 'onKeyDown':this.handleKeyDown, 'placeholder': "tag"});
|
||||
return [
|
||||
React.DOM.input({'type':'text', 'list':'tagListData', 'onKeyDown':this.handleKeyDown, 'placeholder': "tag"}),
|
||||
React.DOM.datalist({'id':'tagListData'}, MochiKit.Base.map(function (aTag) { return React.DOM.option({}, aTag); }, this.listOfTagsNotUsedYet()))
|
||||
];
|
||||
},
|
||||
|
||||
render: function () {
|
||||
|
@ -24,6 +24,10 @@ refer to http://www.clipperz.com.
|
||||
Clipperz.Base.module('Clipperz.PM.UI.Components.Pages');
|
||||
|
||||
Clipperz.PM.UI.Components.Pages.CardDetailPage = React.createClass({
|
||||
propTypes: {
|
||||
'allTags': React.PropTypes.array,
|
||||
},
|
||||
|
||||
/*
|
||||
viewComponentProps: function () {
|
||||
var result;
|
||||
|
@ -33,6 +33,8 @@ Clipperz.PM.UI.Components.Pages.MainPage = React.createClass({
|
||||
},
|
||||
|
||||
propTypes: {
|
||||
'tags': React.PropTypes.object,
|
||||
'allTags': React.PropTypes.array,
|
||||
'messageBox': React.PropTypes.object.isRequired,
|
||||
'featureSet': React.PropTypes.oneOf(['FULL', 'EXPIRED', 'TRIAL', 'OFFLINE']).isRequired,
|
||||
'accountInfo': React.PropTypes.object.isRequired,
|
||||
|
@ -29,9 +29,10 @@ Clipperz.PM.UI.Components.Panels.MainPanel = React.createClass({
|
||||
//=========================================================================
|
||||
|
||||
propTypes: {
|
||||
'messageBox': React.PropTypes.object.isRequired,
|
||||
'featureSet': React.PropTypes.oneOf(['FULL', 'EXPIRED', 'TRIAL', 'OFFLINE']).isRequired,
|
||||
'style': React.PropTypes.oneOf(Clipperz_PM_UI_availableStyles).isRequired,
|
||||
'allTags': React.PropTypes.array,
|
||||
'messageBox': React.PropTypes.object.isRequired,
|
||||
'featureSet': React.PropTypes.oneOf(['FULL', 'EXPIRED', 'TRIAL', 'OFFLINE']).isRequired,
|
||||
'style': React.PropTypes.oneOf(Clipperz_PM_UI_availableStyles).isRequired,
|
||||
},
|
||||
|
||||
style: function () {
|
||||
|
@ -242,12 +242,11 @@ console.log("THE BROWSER IS OFFLINE");
|
||||
shouldShowRegistrationForm = parameters['shouldShowRegistrationForm'] && canRegisterNewUsers;
|
||||
this.pages()['loginPage'].setProps({'mode':this.loginMode(), 'isNewUserRegistrationAvailable':canRegisterNewUsers});
|
||||
|
||||
this.showLoginForm();
|
||||
if (shouldShowRegistrationForm) {
|
||||
this.showRegistrationForm_handler();
|
||||
} else {
|
||||
this.showLoginForm();
|
||||
}
|
||||
|
||||
|
||||
// this.overlay().done("", 0.5);
|
||||
this.overlay().hide();
|
||||
},
|
||||
@ -725,6 +724,9 @@ console.log("THE BROWSER IS OFFLINE");
|
||||
// MochiKit.Base.method(this.user(), 'getTags', this.shouldIncludeArchivedCards()),
|
||||
MochiKit.Base.method(this, 'allTags', this.shouldIncludeArchivedCards()),
|
||||
MochiKit.Base.method(this, 'setPageProperties', 'mainPage', 'tags'),
|
||||
MochiKit.Base.method(this, 'allTags', true || this.shouldIncludeArchivedCards()),
|
||||
MochiKit.Base.keys,
|
||||
MochiKit.Base.method(this, 'setPageProperties', 'mainPage', 'allTags'),
|
||||
MochiKit.Base.method(this, 'getAllCardsCount'),
|
||||
MochiKit.Base.method(this, 'setPageProperties', 'mainPage', 'allCardsCount'),
|
||||
MochiKit.Base.method(this, 'getArchivedCardsCount'),
|
||||
|
Loading…
Reference in New Issue
Block a user