1
0
mirror of http://git.whoc.org.uk/git/password-manager.git synced 2025-01-10 07:10:02 +01:00

Improved feedback when cancelling/saving changes

This commit is contained in:
Giulio Cesare Solaroli 2014-09-05 18:17:41 +02:00
parent 54b264b6a1
commit 5b8da33360
8 changed files with 48 additions and 68 deletions

View File

@ -96,6 +96,7 @@ Clipperz_normalizedNewLine = '\x0d\x0a';
<span class="icon done" style="display:none">done</span> <span class="icon done" style="display:none">done</span>
<span class="icon failed" style="display:none">failed</span> <span class="icon failed" style="display:none">failed</span>
<span class="title">loading</span> <span class="title">loading</span>
<div class="mask hidden" />
</div> </div>
@js_LINKED@ @js_LINKED@

View File

@ -31,7 +31,8 @@ Clipperz.PM.UI.Components.Cards.Detail = React.createClass({
result = this.props['selectedCard']; result = this.props['selectedCard'];
if (result) { if (result) {
result['style'] = this.props['style']; result['style'] = this.props['style'];
result['ask'] = this.props['ask']; result['ask'] = (this.props['style'] == 'narrow') ? this.props['ask'] : null;
result['showGlobalMask'] = this.props['showGlobalMask'];
} }
return result; return result;

View File

@ -51,23 +51,7 @@ Clipperz.PM.UI.Components.Cards.Edit = React.createClass({
fields: function () { fields: function () {
return this.props['fields']; return this.props['fields'];
}, },
/*
sortedFields: function () {
var result;
var from = this.state['fromFieldPosition'];
var to = this.state['toFieldPosition'];
// console.log("FIELDS", this.fields());
if ((from != -1) && (to != -1) && (from != to)) {
result = MochiKit.Base.clone(this.fields());
result.splice(to, 0, result.splice(from, 1)[0]);
} else {
result = this.fields();
}
return result;
},
*/
//============================================================================ //============================================================================
positionOfField: function (aFieldReference) { positionOfField: function (aFieldReference) {
@ -90,16 +74,6 @@ Clipperz.PM.UI.Components.Cards.Edit = React.createClass({
'toFieldPosition': -1, 'toFieldPosition': -1,
'dropPosition': -1 'dropPosition': -1
})); }));
// this.setState({
// 'draggedFieldReference': fieldReference,
// 'fromFieldPosition': fieldPosition
/// 'toFieldPosition': 0
// });
// anEvent.dataTransfer.effectAllowed = 'move';
// anEvent.dataTransfer.setData('text/html', this.innerHTML);
// anEvent.dropEffect
}, },
/* /*
drag: function (anEvent) { drag: function (anEvent) {
@ -237,7 +211,6 @@ console.log("DROP"); //, anEvent);
return function (anEvent) { return function (anEvent) {
method(anEvent.target.value); method(anEvent.target.value);
MochiKit.Signal.signal(Clipperz.Signal.NotificationCenter, 'refreshCardEditDetail', reference); MochiKit.Signal.signal(Clipperz.Signal.NotificationCenter, 'refreshCardEditDetail', reference);
// MochiKit.Signal.signal(Clipperz.Signal.NotificationCenter, 'refreshCardEditToolbar', reference);
}; };
}, },
@ -383,9 +356,9 @@ console.log("DROP"); //, anEvent);
'edit': true 'edit': true
} }
//console.log("RENDER CARD EDIT"); //console.log("RENDER CARD EDIT", this.props['showGlobalMask']);
return React.DOM.div({'className':'editWrapper'}, [ return React.DOM.div({'className':'editWrapper'}, [
React.DOM.div({'className':'mask'}), this.props['showGlobalMask'] ? null : React.DOM.div({'className':'mask'}),
React.DOM.div({'className':React.addons.classSet(classes)},[ React.DOM.div({'className':React.addons.classSet(classes)},[
Clipperz.PM.UI.Components.Cards.EditToolbar(this.props), Clipperz.PM.UI.Components.Cards.EditToolbar(this.props),
React.DOM.div({'className':'content'}, [ React.DOM.div({'className':'content'}, [

View File

@ -53,7 +53,11 @@ Clipperz.Base.extend(Clipperz.PM.UI.Components.Overlay, Object, {
//------------------------------------------------------------------------- //-------------------------------------------------------------------------
'show': function (aMessage) { 'show': function (aMessage, showMask) {
if (showMask === true) {
this.showMask();
}
this.resetStatus(); this.resetStatus();
this.setMessage(aMessage); this.setMessage(aMessage);
MochiKit.DOM.removeElementClass(this.element(), 'ios-overlay-hide'); MochiKit.DOM.removeElementClass(this.element(), 'ios-overlay-hide');
@ -61,6 +65,7 @@ Clipperz.Base.extend(Clipperz.PM.UI.Components.Overlay, Object, {
}, },
'done': function (aMessage, aDelayBeforeHiding) { 'done': function (aMessage, aDelayBeforeHiding) {
this.hideMask();
this.completed(this.showDoneIcon, aMessage, aDelayBeforeHiding); this.completed(this.showDoneIcon, aMessage, aDelayBeforeHiding);
}, },
@ -70,6 +75,20 @@ Clipperz.Base.extend(Clipperz.PM.UI.Components.Overlay, Object, {
//------------------------------------------------------------------------- //-------------------------------------------------------------------------
'maskElement': function () {
return this.getElement('mask');
},
'showMask': function () {
MochiKit.DOM.removeElementClass(this.maskElement(), 'hidden');
},
'hideMask': function () {
MochiKit.DOM.addElementClass(this.maskElement(), 'hidden');
},
//-------------------------------------------------------------------------
'resetStatus': function () { 'resetStatus': function () {
MochiKit.Style.showElement(this.element()); MochiKit.Style.showElement(this.element());
MochiKit.Style.showElement(this.getElement('spinner')); MochiKit.Style.showElement(this.getElement('spinner'));

View File

@ -54,7 +54,7 @@ Clipperz.PM.UI.Components.Pages.MainPage = React.createClass({
}; };
classes[this.props['style']] = true; classes[this.props['style']] = true;
//console.log("MAIN PAGE", this.props['ask']); //console.log("MAIN PAGE", this.props['showGlobalMask']);
return React.DOM.div({'className':React.addons.classSet(classes)}, [ return React.DOM.div({'className':React.addons.classSet(classes)}, [
this.props['style'] != 'extra-wide' ? Clipperz.PM.UI.Components.Panels.SelectionPanel(this.props) : null, this.props['style'] != 'extra-wide' ? Clipperz.PM.UI.Components.Panels.SelectionPanel(this.props) : null,
Clipperz.PM.UI.Components.Panels.MainPanel(this.props), Clipperz.PM.UI.Components.Panels.MainPanel(this.props),

View File

@ -93,30 +93,6 @@ Clipperz.PM.UI.Components.Panels.MainPanel = React.createClass({
}, },
//---------------------------------------------------------------------------- //----------------------------------------------------------------------------
/*
viewComponentProps: function () {
var result;
result = this.props['selectedCard'];
if (result) {
result['style'] = this.props['style'];
}
return result;
},
renderCardDetail: function () {
var result;
//console.log("PROPS", this.props);
if (this.props['mode'] == 'edit') {
result = Clipperz.PM.UI.Components.Cards.Edit(this.viewComponentProps());
} else {
result = Clipperz.PM.UI.Components.Cards.View(this.viewComponentProps());
}
return result;
},
*/
renderCardDetail: function () { renderCardDetail: function () {
return Clipperz.PM.UI.Components.Cards.Detail(this.props); return Clipperz.PM.UI.Components.Cards.Detail(this.props);
@ -190,7 +166,7 @@ Clipperz.PM.UI.Components.Panels.MainPanel = React.createClass({
}, },
render: function () { render: function () {
//console.log("MainPanel.cards", this.props['ask']); //console.log("MainPanel.render", this.props['showGlobalMask']);
var classes = { var classes = {
'panel': true, 'panel': true,
'left': this.props['selectionPanelStatus'] == 'OPEN', 'left': this.props['selectionPanelStatus'] == 'OPEN',

View File

@ -437,7 +437,8 @@ console.log("SET USER", aUser);
deferredResult.setValue('_reference'); deferredResult.setValue('_reference');
deferredResult.addMethod(aRecord, 'isArchived'); deferredResult.addMethod(aRecord, 'isArchived');
deferredResult.setValue('_isArchived'); deferredResult.setValue('_isArchived');
deferredResult.addMethod(aRecord, 'hasPendingChanges'); // deferredResult.addMethod(aRecord, 'hasPendingChanges');
deferredResult.addMethod(this.user(), 'hasPendingChanges');
deferredResult.setValue('hasPendingChanges'); deferredResult.setValue('hasPendingChanges');
deferredResult.addMethod(aRecord, 'label'); deferredResult.addMethod(aRecord, 'label');
deferredResult.setValue('label'); deferredResult.setValue('label');
@ -965,11 +966,12 @@ console.log("SET USER", aUser);
var self = this; var self = this;
return Clipperz.Async.callbacks("MainController.saveCardEdits_handler", [ return Clipperz.Async.callbacks("MainController.saveCardEdits_handler", [
MochiKit.Base.method(currentPage, 'setProps', {'showGlobalMask':true}),
MochiKit.Base.method(this.overlay(), 'show', "saving …", true),
MochiKit.Base.method(this.user(), 'saveChanges'), MochiKit.Base.method(this.user(), 'saveChanges'),
MochiKit.Base.method(currentPage, 'setProps', {'mode':'view'}), MochiKit.Base.method(currentPage, 'setProps', {'mode':'view', 'showGlobalMask':false}),
// MochiKit.Base.method(self, 'updateSelectedCard', {'reference':aRecordReference}, false), MochiKit.Base.method(this, 'refreshUI', aRecordReference),
// MochiKit.Base.method(self, 'refreshUI'), MochiKit.Base.method(this.overlay(), 'done', "saved", 1),
MochiKit.Base.method(this, 'refreshUI', aRecordReference)
], {trace:false}); ], {trace:false});
}, },
@ -992,12 +994,12 @@ console.log("SET USER", aUser);
'cancel': {'label':"No", 'isDefault':true, 'answer':MochiKit.Base.methodcaller('cancel', new MochiKit.Async.CancelledError())}, 'cancel': {'label':"No", 'isDefault':true, 'answer':MochiKit.Base.methodcaller('cancel', new MochiKit.Async.CancelledError())},
'revert': {'label':"Yes", 'isDefault':false, 'answer':MochiKit.Base.methodcaller('callback')} 'revert': {'label':"Yes", 'isDefault':false, 'answer':MochiKit.Base.methodcaller('callback')}
} }
}) }),
], [ ], [
// MochiKit.Async.succeed // MochiKit.Async.succeed
]), ]),
MochiKit.Base.method(currentPage, 'setProps', {'mode':'view'}),
MochiKit.Base.method(this.user(), 'revertChanges'), MochiKit.Base.method(this.user(), 'revertChanges'),
MochiKit.Base.method(currentPage, 'setProps', {'mode':'view'}),
MochiKit.Base.bind(function () { MochiKit.Base.bind(function () {
var info; var info;
@ -1030,11 +1032,9 @@ console.log("SET USER", aUser);
var currentPage = this.pages()[this.currentPage()]; var currentPage = this.pages()[this.currentPage()];
deferredResult = new Clipperz.Async.Deferred('MainController.ask', {trace:false}); deferredResult = new Clipperz.Async.Deferred('MainController.ask', {trace:false});
currentPage.setProps({'ask': {'info': someInfo, 'deferred':deferredResult}}); currentPage.setProps({'ask': {'info': someInfo, 'deferred':deferredResult}, 'showGlobalMask':true });
// deferredResult.addCallback(function (aResult) { console.log("ASK - OK", aResult); return aResult; }); deferredResult.addBothPass(MochiKit.Base.method(currentPage, 'setProps', {'ask': null, 'showGlobalMask':false }));
// deferredResult.addErrback(function (aResult) { console.log("ASK - FAIL", aResult); return aResult; });
deferredResult.addBothPass(MochiKit.Base.method(currentPage, 'setProps', {'ask': null}));
return deferredResult; return deferredResult;
}, },

View File

@ -1,6 +1,16 @@
@import "mixin"; @import "mixin";
div.overlay { div.overlay {
@include mask;
.mask {
position: fixed;
z-index: -2;
&.hidden {
display: none;
}
}
z-index: 99999; z-index: 99999;
position: fixed; position: fixed;
top: 50%; top: 50%;