鏡像自
http://git.whoc.org.uk/git/password-manager.git
已同步 2025-10-24 01:07:35 +02:00
Minor UI/UX improvements.
此提交包含在:
@@ -119,6 +119,7 @@ http://jonibologna.com/flexbox-cheatsheet/
|
|||||||
-ms-transform: rotate(0deg) translate(0, 0);
|
-ms-transform: rotate(0deg) translate(0, 0);
|
||||||
-o-transform: rotate(0deg) translate(0, 0);
|
-o-transform: rotate(0deg) translate(0, 0);
|
||||||
transform: rotate(0deg) translate(0, 0); }
|
transform: rotate(0deg) translate(0, 0); }
|
||||||
|
|
||||||
100% {
|
100% {
|
||||||
-webkit-transform: rotate(359deg) translate(0, 0);
|
-webkit-transform: rotate(359deg) translate(0, 0);
|
||||||
-moz-transform: rotate(359deg) translate(0, 0);
|
-moz-transform: rotate(359deg) translate(0, 0);
|
||||||
@@ -132,6 +133,7 @@ http://jonibologna.com/flexbox-cheatsheet/
|
|||||||
-ms-transform: rotate(0deg) translate(0, 0);
|
-ms-transform: rotate(0deg) translate(0, 0);
|
||||||
-o-transform: rotate(0deg) translate(0, 0);
|
-o-transform: rotate(0deg) translate(0, 0);
|
||||||
transform: rotate(0deg) translate(0, 0); }
|
transform: rotate(0deg) translate(0, 0); }
|
||||||
|
|
||||||
100% {
|
100% {
|
||||||
-webkit-transform: rotate(359deg) translate(0, 0);
|
-webkit-transform: rotate(359deg) translate(0, 0);
|
||||||
-moz-transform: rotate(359deg) translate(0, 0);
|
-moz-transform: rotate(359deg) translate(0, 0);
|
||||||
@@ -145,6 +147,7 @@ http://jonibologna.com/flexbox-cheatsheet/
|
|||||||
-ms-transform: rotate(0deg) translate(0, 0);
|
-ms-transform: rotate(0deg) translate(0, 0);
|
||||||
-o-transform: rotate(0deg) translate(0, 0);
|
-o-transform: rotate(0deg) translate(0, 0);
|
||||||
transform: rotate(0deg) translate(0, 0); }
|
transform: rotate(0deg) translate(0, 0); }
|
||||||
|
|
||||||
100% {
|
100% {
|
||||||
-webkit-transform: rotate(359deg) translate(0, 0);
|
-webkit-transform: rotate(359deg) translate(0, 0);
|
||||||
-moz-transform: rotate(359deg) translate(0, 0);
|
-moz-transform: rotate(359deg) translate(0, 0);
|
||||||
@@ -158,6 +161,7 @@ http://jonibologna.com/flexbox-cheatsheet/
|
|||||||
-ms-transform: rotate(0deg) translate(0, 0);
|
-ms-transform: rotate(0deg) translate(0, 0);
|
||||||
-o-transform: rotate(0deg) translate(0, 0);
|
-o-transform: rotate(0deg) translate(0, 0);
|
||||||
transform: rotate(0deg) translate(0, 0); }
|
transform: rotate(0deg) translate(0, 0); }
|
||||||
|
|
||||||
100% {
|
100% {
|
||||||
-webkit-transform: rotate(359deg) translate(0, 0);
|
-webkit-transform: rotate(359deg) translate(0, 0);
|
||||||
-moz-transform: rotate(359deg) translate(0, 0);
|
-moz-transform: rotate(359deg) translate(0, 0);
|
||||||
@@ -190,6 +194,18 @@ div.overlay {
|
|||||||
z-index: -2; }
|
z-index: -2; }
|
||||||
div.overlay .mask.hidden {
|
div.overlay .mask.hidden {
|
||||||
display: none; }
|
display: none; }
|
||||||
|
div.overlay .mask.card {
|
||||||
|
top: 48px; }
|
||||||
|
.extra-wide div.overlay .mask.card {
|
||||||
|
left: 46.6%; }
|
||||||
|
.wide div.overlay .mask.card {
|
||||||
|
left: 33.3%; }
|
||||||
|
.narrow div.overlay .mask.card {
|
||||||
|
left: 100%; }
|
||||||
|
.extra-wide div.overlay.card {
|
||||||
|
left: 74%; }
|
||||||
|
.wide div.overlay.card {
|
||||||
|
left: 66.6%; }
|
||||||
div.overlay .title {
|
div.overlay .title {
|
||||||
color: #FFF;
|
color: #FFF;
|
||||||
font-weight: bold;
|
font-weight: bold;
|
||||||
@@ -222,7 +238,7 @@ div.overlay {
|
|||||||
font-size: 96pt;
|
font-size: 96pt;
|
||||||
color: white;
|
color: white;
|
||||||
text-shadow: none; }
|
text-shadow: none; }
|
||||||
div.overlay.ios-overlay-show {
|
div.overlay.ios-overlay-show:not(.card) {
|
||||||
-webkit-animation-name: ios-overlay-show;
|
-webkit-animation-name: ios-overlay-show;
|
||||||
-webkit-animation-duration: 750ms;
|
-webkit-animation-duration: 750ms;
|
||||||
-webkit-animation-timing-function: linear;
|
-webkit-animation-timing-function: linear;
|
||||||
@@ -248,7 +264,7 @@ div.overlay {
|
|||||||
animation-timing-function: linear;
|
animation-timing-function: linear;
|
||||||
animation-iteration-count: 1;
|
animation-iteration-count: 1;
|
||||||
animation-fill-mode: none; }
|
animation-fill-mode: none; }
|
||||||
div.overlay.ios-overlay-hide {
|
div.overlay.ios-overlay-hide:not(.card) {
|
||||||
-webkit-animation-name: ios-overlay-hide;
|
-webkit-animation-name: ios-overlay-hide;
|
||||||
-webkit-animation-duration: 750ms;
|
-webkit-animation-duration: 750ms;
|
||||||
-webkit-animation-timing-function: linear;
|
-webkit-animation-timing-function: linear;
|
||||||
@@ -478,61 +494,73 @@ div.overlay {
|
|||||||
@-webkit-keyframes overlay-spin {
|
@-webkit-keyframes overlay-spin {
|
||||||
from {
|
from {
|
||||||
opacity: 1; }
|
opacity: 1; }
|
||||||
|
|
||||||
to {
|
to {
|
||||||
opacity: 0.25; } }
|
opacity: 0.25; } }
|
||||||
@-moz-keyframes overlay-spin {
|
@-moz-keyframes overlay-spin {
|
||||||
from {
|
from {
|
||||||
opacity: 1; }
|
opacity: 1; }
|
||||||
|
|
||||||
to {
|
to {
|
||||||
opacity: 0.25; } }
|
opacity: 0.25; } }
|
||||||
@-ms-keyframes overlay-spin {
|
@-ms-keyframes overlay-spin {
|
||||||
from {
|
from {
|
||||||
opacity: 1; }
|
opacity: 1; }
|
||||||
|
|
||||||
to {
|
to {
|
||||||
opacity: 0.25; } }
|
opacity: 0.25; } }
|
||||||
@keyframes overlay-spin {
|
@keyframes overlay-spin {
|
||||||
from {
|
from {
|
||||||
opacity: 1; }
|
opacity: 1; }
|
||||||
|
|
||||||
to {
|
to {
|
||||||
opacity: 0.25; } }
|
opacity: 0.25; } }
|
||||||
@-webkit-keyframes ios-overlay-show {
|
@-webkit-keyframes ios-overlay-show {
|
||||||
0% {
|
0% {
|
||||||
opacity: 0; }
|
opacity: 0; }
|
||||||
|
|
||||||
100% {
|
100% {
|
||||||
opacity: 1; } }
|
opacity: 1; } }
|
||||||
@-moz-keyframes ios-overlay-show {
|
@-moz-keyframes ios-overlay-show {
|
||||||
0% {
|
0% {
|
||||||
opacity: 0; }
|
opacity: 0; }
|
||||||
|
|
||||||
100% {
|
100% {
|
||||||
opacity: 1; } }
|
opacity: 1; } }
|
||||||
@-ms-keyframes ios-overlay-show {
|
@-ms-keyframes ios-overlay-show {
|
||||||
0% {
|
0% {
|
||||||
opacity: 0; }
|
opacity: 0; }
|
||||||
|
|
||||||
100% {
|
100% {
|
||||||
opacity: 1; } }
|
opacity: 1; } }
|
||||||
@keyframes ios-overlay-show {
|
@keyframes ios-overlay-show {
|
||||||
0% {
|
0% {
|
||||||
opacity: 0; }
|
opacity: 0; }
|
||||||
|
|
||||||
100% {
|
100% {
|
||||||
opacity: 1; } }
|
opacity: 1; } }
|
||||||
@-webkit-keyframes ios-overlay-hide {
|
@-webkit-keyframes ios-overlay-hide {
|
||||||
0% {
|
0% {
|
||||||
opacity: 1; }
|
opacity: 1; }
|
||||||
|
|
||||||
100% {
|
100% {
|
||||||
opacity: 0; } }
|
opacity: 0; } }
|
||||||
@-moz-keyframes ios-overlay-hide {
|
@-moz-keyframes ios-overlay-hide {
|
||||||
0% {
|
0% {
|
||||||
opacity: 1; }
|
opacity: 1; }
|
||||||
|
|
||||||
100% {
|
100% {
|
||||||
opacity: 0; } }
|
opacity: 0; } }
|
||||||
@-ms-keyframes ios-overlay-hide {
|
@-ms-keyframes ios-overlay-hide {
|
||||||
0% {
|
0% {
|
||||||
opacity: 1; }
|
opacity: 1; }
|
||||||
|
|
||||||
100% {
|
100% {
|
||||||
opacity: 0; } }
|
opacity: 0; } }
|
||||||
@keyframes ios-overlay-hide {
|
@keyframes ios-overlay-hide {
|
||||||
0% {
|
0% {
|
||||||
opacity: 1; }
|
opacity: 1; }
|
||||||
|
|
||||||
100% {
|
100% {
|
||||||
opacity: 0; } }
|
opacity: 0; } }
|
||||||
/*
|
/*
|
||||||
@@ -2494,13 +2522,13 @@ span.count {
|
|||||||
#extraFeaturesPanel .extraFeatureIndex footer {
|
#extraFeaturesPanel .extraFeatureIndex footer {
|
||||||
font-size: 8pt;
|
font-size: 8pt;
|
||||||
padding: 5px 5px 5px 5px;
|
padding: 5px 5px 5px 5px;
|
||||||
border-top: 1px solid #999; }
|
border-top: 1px solid #999999; }
|
||||||
#extraFeaturesPanel .extraFeatureIndex footer span {
|
#extraFeaturesPanel .extraFeatureIndex footer span {
|
||||||
color: #999; }
|
color: #999999; }
|
||||||
#extraFeaturesPanel .extraFeatureIndex footer span:after {
|
#extraFeaturesPanel .extraFeatureIndex footer span:after {
|
||||||
content: ":"; }
|
content: ":"; }
|
||||||
#extraFeaturesPanel .extraFeatureIndex footer a {
|
#extraFeaturesPanel .extraFeatureIndex footer a {
|
||||||
color: #999;
|
color: #999999;
|
||||||
text-decoration: none;
|
text-decoration: none;
|
||||||
padding-left: 5px;
|
padding-left: 5px;
|
||||||
font-weight: bold; }
|
font-weight: bold; }
|
||||||
@@ -3298,7 +3326,7 @@ div.cardList ul {
|
|||||||
padding-right: 0px;
|
padding-right: 0px;
|
||||||
box-shadow: -4px 0px 3px -1px rgba(0, 0, 0, 0.2); }
|
box-shadow: -4px 0px 3px -1px rgba(0, 0, 0, 0.2); }
|
||||||
div.cardList ul li.archived {
|
div.cardList ul li.archived {
|
||||||
background-color: #eee;
|
background-color: #eeeeee;
|
||||||
color: #999; }
|
color: #999; }
|
||||||
div.cardList ul li .favicon {
|
div.cardList ul li .favicon {
|
||||||
width: 48px;
|
width: 48px;
|
||||||
@@ -3398,7 +3426,7 @@ div.cardList.narrow {
|
|||||||
content: ""; }
|
content: ""; }
|
||||||
|
|
||||||
#cardDetailPage .view.archived, .cardDetail .view.archived {
|
#cardDetailPage .view.archived, .cardDetail .view.archived {
|
||||||
background-color: #eee; }
|
background-color: #eeeeee; }
|
||||||
#cardDetailPage .view .cardDetailToolbar, .cardDetail .view .cardDetailToolbar {
|
#cardDetailPage .view .cardDetailToolbar, .cardDetail .view .cardDetailToolbar {
|
||||||
background-color: #1863a1;
|
background-color: #1863a1;
|
||||||
color: white; }
|
color: white; }
|
||||||
@@ -3848,7 +3876,7 @@ div.cardList.narrow {
|
|||||||
cursor: grab;
|
cursor: grab;
|
||||||
cursor: -moz-grab;
|
cursor: -moz-grab;
|
||||||
cursor: -webkit-grab;
|
cursor: -webkit-grab;
|
||||||
background: repeating-linear-gradient(0deg, white, white 2px, #ddd 2px, #ddd 3px);
|
background: repeating-linear-gradient(0deg, white, white 2px, #dddddd 2px, #dddddd 3px);
|
||||||
width: 28px;
|
width: 28px;
|
||||||
height: 20px;
|
height: 20px;
|
||||||
margin-left: 6px;
|
margin-left: 6px;
|
||||||
@@ -4095,7 +4123,7 @@ div.cardList.narrow {
|
|||||||
min-width: 220px;
|
min-width: 220px;
|
||||||
width: 80%;
|
width: 80%;
|
||||||
max-width: 400px;
|
max-width: 400px;
|
||||||
background-color: #333;
|
background-color: #333333;
|
||||||
color: #fff;
|
color: #fff;
|
||||||
-webkit-border-radius: 6px;
|
-webkit-border-radius: 6px;
|
||||||
-moz-border-radius: 6px;
|
-moz-border-radius: 6px;
|
||||||
@@ -4110,7 +4138,7 @@ div.cardList.narrow {
|
|||||||
margin-left: 0px;
|
margin-left: 0px;
|
||||||
width: 0;
|
width: 0;
|
||||||
height: 0;
|
height: 0;
|
||||||
border-top: 5px solid #333;
|
border-top: 5px solid #333333;
|
||||||
border-left: 5px solid transparent;
|
border-left: 5px solid transparent;
|
||||||
border-right: 5px solid transparent; }
|
border-right: 5px solid transparent; }
|
||||||
.passwordGenerator .passwordGeneratorBaloon form span {
|
.passwordGenerator .passwordGeneratorBaloon form span {
|
||||||
|
@@ -423,8 +423,6 @@ Clipperz.PM.UI.Components.Cards.ViewClass = React.createClass({
|
|||||||
render: function () {
|
render: function () {
|
||||||
var result;
|
var result;
|
||||||
|
|
||||||
console.log(this.props['_isBrandNew']);
|
|
||||||
|
|
||||||
if (this.props['loading'] == true) {
|
if (this.props['loading'] == true) {
|
||||||
result = this.renderLoading();
|
result = this.renderLoading();
|
||||||
} else if (this.props['_reference']) {
|
} else if (this.props['_reference']) {
|
||||||
|
@@ -68,7 +68,7 @@ Clipperz.PM.UI.Components.ExtraFeatures.DataExportClass = React.createClass({
|
|||||||
React.DOM.h3({}, "Offline copy"),
|
React.DOM.h3({}, "Offline copy"),
|
||||||
React.DOM.div({'className':'description'}, [
|
React.DOM.div({'className':'description'}, [
|
||||||
React.DOM.p({}, "Download a read-only portable version of Clipperz. Very convenient when no Internet connection is available."),
|
React.DOM.p({}, "Download a read-only portable version of Clipperz. Very convenient when no Internet connection is available."),
|
||||||
React.DOM.p({}, "An offline copy is just a single HTML file that contains both the whole Clipperz web application and your encrypted data."),
|
React.DOM.p({}, "An offline copy is just a single HTML file that contains both the whole Clipperz web application and your encrypted data, except file attachments."),
|
||||||
React.DOM.p({}, "It is as secure as the hosted Clipperz service since they both share the same code and security architecture.")
|
React.DOM.p({}, "It is as secure as the hosted Clipperz service since they both share the same code and security architecture.")
|
||||||
]),
|
]),
|
||||||
React.DOM.a({'className':'button', 'onClick':this.handleDownloadOfflineCopyLink}, "download offline copy")
|
React.DOM.a({'className':'button', 'onClick':this.handleDownloadOfflineCopyLink}, "download offline copy")
|
||||||
@@ -77,7 +77,7 @@ Clipperz.PM.UI.Components.ExtraFeatures.DataExportClass = React.createClass({
|
|||||||
React.DOM.h3({}, "HTML + JSON"),
|
React.DOM.h3({}, "HTML + JSON"),
|
||||||
React.DOM.div({'className':'description'}, [
|
React.DOM.div({'className':'description'}, [
|
||||||
React.DOM.p({}, "Download a printer-friendly HTML file that lists the content of all your cards."),
|
React.DOM.p({}, "Download a printer-friendly HTML file that lists the content of all your cards."),
|
||||||
React.DOM.p({}, "This same file also contains all your data in JSON format."),
|
React.DOM.p({}, "This same file also contains all your data in JSON format. Please note that file attachments are not included."),
|
||||||
React.DOM.p({'className':'warning'}, "Beware: all data are unencrypted! Therefore make sure to properly store and manage this file.")
|
React.DOM.p({'className':'warning'}, "Beware: all data are unencrypted! Therefore make sure to properly store and manage this file.")
|
||||||
]),
|
]),
|
||||||
React.DOM.a({'className':'button', 'onClick':this.handleExportLink}, "download HTML+JSON")
|
React.DOM.a({'className':'button', 'onClick':this.handleExportLink}, "download HTML+JSON")
|
||||||
|
@@ -41,13 +41,23 @@ Clipperz.PM.UI.Components.ExtraFeatures.DevicePINClass = React.createClass({
|
|||||||
//=========================================================================
|
//=========================================================================
|
||||||
|
|
||||||
handleChange: function(anEvent) {
|
handleChange: function(anEvent) {
|
||||||
if (anEvent.target.value.length <= this.props['PIN'].DEFAULT_PIN_LENGTH) {
|
var newValue = anEvent.target.value;
|
||||||
|
|
||||||
|
if (!isNaN(newValue) && newValue.length <= this.props['PIN'].DEFAULT_PIN_LENGTH) {
|
||||||
this.setState({
|
this.setState({
|
||||||
'pinValue': anEvent.target.value
|
'pinValue': anEvent.target.value
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
handleSubmit: function(anEvent) {
|
||||||
|
var isSubmitEnabled = (this.state['pinValue'].length == this.props['PIN'].DEFAULT_PIN_LENGTH);
|
||||||
|
|
||||||
|
if (isSubmitEnabled) { this.savePIN(); }
|
||||||
|
|
||||||
|
anEvent.preventDefault();
|
||||||
|
},
|
||||||
|
|
||||||
setFocus: function() {
|
setFocus: function() {
|
||||||
this.refs['pinValue'].getDOMNode().focus();
|
this.refs['pinValue'].getDOMNode().focus();
|
||||||
},
|
},
|
||||||
@@ -94,7 +104,9 @@ Clipperz.PM.UI.Components.ExtraFeatures.DevicePINClass = React.createClass({
|
|||||||
React.DOM.div({'className': 'content'}, [
|
React.DOM.div({'className': 'content'}, [
|
||||||
// React.DOM.p({}, "PIN is "+((this.props['PIN'].isSet()) ? '' : 'not ')+"set on this device"),
|
// React.DOM.p({}, "PIN is "+((this.props['PIN'].isSet()) ? '' : 'not ')+"set on this device"),
|
||||||
React.DOM.p({}, ((this.props['PIN'].isSet()) ? "PIN is set on this device" : "PIN is not set on this device")),
|
React.DOM.p({}, ((this.props['PIN'].isSet()) ? "PIN is set on this device" : "PIN is not set on this device")),
|
||||||
React.DOM.form({},[
|
React.DOM.form({
|
||||||
|
'onSubmit': this.handleSubmit,
|
||||||
|
},[
|
||||||
React.DOM.input({
|
React.DOM.input({
|
||||||
'type': 'tel',
|
'type': 'tel',
|
||||||
'key': 'pinValue',
|
'key': 'pinValue',
|
||||||
|
@@ -53,9 +53,9 @@ Clipperz.Base.extend(Clipperz.PM.UI.Components.Overlay, Object, {
|
|||||||
|
|
||||||
//-------------------------------------------------------------------------
|
//-------------------------------------------------------------------------
|
||||||
|
|
||||||
'show': function (aMessage, showMask, showProgress) {
|
'show': function (aMessage, showMask, showProgress, showOnCardDetail) {
|
||||||
if (showMask === true) {
|
if (showMask === true) {
|
||||||
this.showMask();
|
this.showMask(showOnCardDetail);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (showProgress === true) {
|
if (showProgress === true) {
|
||||||
@@ -68,6 +68,12 @@ Clipperz.Base.extend(Clipperz.PM.UI.Components.Overlay, Object, {
|
|||||||
MochiKit.DOM.removeElementClass(this.element(), 'spinnerOnly');
|
MochiKit.DOM.removeElementClass(this.element(), 'spinnerOnly');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (showOnCardDetail) {
|
||||||
|
MochiKit.DOM.addElementClass(this.element(), 'card');
|
||||||
|
} else {
|
||||||
|
MochiKit.DOM.removeElementClass(this.element(), 'card');
|
||||||
|
}
|
||||||
|
|
||||||
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');
|
||||||
@@ -90,7 +96,12 @@ Clipperz.Base.extend(Clipperz.PM.UI.Components.Overlay, Object, {
|
|||||||
return this.getElement('mask');
|
return this.getElement('mask');
|
||||||
},
|
},
|
||||||
|
|
||||||
'showMask': function () {
|
'showMask': function (showOnCardDetail) {
|
||||||
|
MochiKit.DOM.removeElementClass(this.maskElement(), 'card');
|
||||||
|
|
||||||
|
if (showOnCardDetail) {
|
||||||
|
MochiKit.DOM.addElementClass(this.maskElement(), 'card');
|
||||||
|
}
|
||||||
MochiKit.DOM.removeElementClass(this.maskElement(), 'hidden');
|
MochiKit.DOM.removeElementClass(this.maskElement(), 'hidden');
|
||||||
},
|
},
|
||||||
|
|
||||||
@@ -123,12 +134,13 @@ Clipperz.Base.extend(Clipperz.PM.UI.Components.Overlay, Object, {
|
|||||||
return MochiKit.Async.callLater(delay, MochiKit.Base.bind(this.hide, this))
|
return MochiKit.Async.callLater(delay, MochiKit.Base.bind(this.hide, this))
|
||||||
},
|
},
|
||||||
|
|
||||||
'hide': function () {
|
'hide': function (withoutAnimationTime) {
|
||||||
|
var secondsBeforeHiding = withoutAnimationTime ? 0 : 1;
|
||||||
var element = this.element();
|
var element = this.element();
|
||||||
this.hideProgressBar();
|
this.hideProgressBar();
|
||||||
MochiKit.DOM.removeElementClass(element, 'ios-overlay-show');
|
MochiKit.DOM.removeElementClass(element, 'ios-overlay-show');
|
||||||
MochiKit.DOM.addElementClass(element, 'ios-overlay-hide');
|
MochiKit.DOM.addElementClass(element, 'ios-overlay-hide');
|
||||||
return MochiKit.Async.callLater(1, MochiKit.Style.hideElement, element);
|
return MochiKit.Async.callLater(secondsBeforeHiding, MochiKit.Style.hideElement, element);
|
||||||
},
|
},
|
||||||
|
|
||||||
'hideSpinner': function () {
|
'hideSpinner': function () {
|
||||||
|
@@ -73,7 +73,7 @@ Clipperz.PM.UI.Components.Pages.UnlockPageClass = React.createClass({
|
|||||||
this.refs['passphrase'].getDOMNode().blur();
|
this.refs['passphrase'].getDOMNode().blur();
|
||||||
MochiKit.Signal.signal(Clipperz.Signal.NotificationCenter, 'unlock', this.refs['passphrase'].getDOMNode().value, 'PASSPHRASE');
|
MochiKit.Signal.signal(Clipperz.Signal.NotificationCenter, 'unlock', this.refs['passphrase'].getDOMNode().value, 'PASSPHRASE');
|
||||||
|
|
||||||
this.resetUnlockForm();
|
// this.resetUnlockForm();
|
||||||
},
|
},
|
||||||
|
|
||||||
submitPIN: function() {
|
submitPIN: function() {
|
||||||
@@ -83,7 +83,7 @@ Clipperz.PM.UI.Components.Pages.UnlockPageClass = React.createClass({
|
|||||||
|
|
||||||
MochiKit.Signal.signal(Clipperz.Signal.NotificationCenter, 'unlock', pin, 'PIN');
|
MochiKit.Signal.signal(Clipperz.Signal.NotificationCenter, 'unlock', pin, 'PIN');
|
||||||
|
|
||||||
this.resetUnlockForm();
|
// this.resetUnlockForm();
|
||||||
},
|
},
|
||||||
|
|
||||||
resetUnlockForm: function() {
|
resetUnlockForm: function() {
|
||||||
|
@@ -429,6 +429,7 @@ Clipperz.log("THE BROWSER IS OFFLINE");
|
|||||||
deferredResult.addMethod(this.user(), 'lock');
|
deferredResult.addMethod(this.user(), 'lock');
|
||||||
deferredResult.addMethod(this, 'deleteCleanTextData');
|
deferredResult.addMethod(this, 'deleteCleanTextData');
|
||||||
deferredResult.addMethod(this.pages()['unlockPage'], 'setProps', {'username': this.user().username()});
|
deferredResult.addMethod(this.pages()['unlockPage'], 'setProps', {'username': this.user().username()});
|
||||||
|
deferredResult.addCallback(MochiKit.Async.callLater, 0.1, MochiKit.Base.method(this.pages()['unlockPage'], 'resetUnlockForm'));
|
||||||
deferredResult.addMethod(this.pages()['unlockPage'], 'setInitialFocus');
|
deferredResult.addMethod(this.pages()['unlockPage'], 'setInitialFocus');
|
||||||
deferredResult.addCallback(MochiKit.Async.callLater, 1, MochiKit.Base.method(this.pages()['mainPage'], 'replaceProps', {'locked': true}));
|
deferredResult.addCallback(MochiKit.Async.callLater, 1, MochiKit.Base.method(this.pages()['mainPage'], 'replaceProps', {'locked': true}));
|
||||||
|
|
||||||
@@ -496,7 +497,7 @@ Clipperz.log("THE BROWSER IS OFFLINE");
|
|||||||
'disabled': false,
|
'disabled': false,
|
||||||
'forceCredentials': false,
|
'forceCredentials': false,
|
||||||
});
|
});
|
||||||
deferredResult.addMethod(unlockPage, 'resetUnlockForm');
|
// deferredResult.addMethod(unlockPage, 'resetUnlockForm');
|
||||||
deferredResult.addCallback(MochiKit.Signal.signal, Clipperz.Signal.NotificationCenter, 'enableLock');
|
deferredResult.addCallback(MochiKit.Signal.signal, Clipperz.Signal.NotificationCenter, 'enableLock');
|
||||||
deferredResult.addMethod(overlay, 'done', "", 0.5);
|
deferredResult.addMethod(overlay, 'done', "", 0.5);
|
||||||
|
|
||||||
@@ -706,7 +707,8 @@ Clipperz.log("THE BROWSER IS OFFLINE");
|
|||||||
deferredResult = MochiKit.Async.succeed();
|
deferredResult = MochiKit.Async.succeed();
|
||||||
} else {
|
} else {
|
||||||
if (showLoading) {
|
if (showLoading) {
|
||||||
this.setPageProperties('mainPage', 'selectedCard', {'loading':true, 'label':someInfo['label'], '_reference':someInfo['reference']});
|
// this.setPageProperties('mainPage', 'selectedCard', {'loading':true, 'label':someInfo['label'], '_reference':someInfo['reference']});
|
||||||
|
this.overlay().show('', true, false, true)
|
||||||
}
|
}
|
||||||
|
|
||||||
deferredResult = new Clipperz.Async.Deferred('MainController.updateSelectedCard', {trace:false});
|
deferredResult = new Clipperz.Async.Deferred('MainController.updateSelectedCard', {trace:false});
|
||||||
@@ -717,6 +719,7 @@ Clipperz.log("THE BROWSER IS OFFLINE");
|
|||||||
if ((this.mediaQueryStyle() == 'narrow') && shouldShowCardDetail) {
|
if ((this.mediaQueryStyle() == 'narrow') && shouldShowCardDetail) {
|
||||||
deferredResult.addMethod(this, 'showCardDetailInNarrowView');
|
deferredResult.addMethod(this, 'showCardDetailInNarrowView');
|
||||||
}
|
}
|
||||||
|
deferredResult.addMethod(this.overlay(), 'hide', true);
|
||||||
|
|
||||||
MochiKit.Async.callLater(0.1, MochiKit.Base.method(deferredResult, 'callback'));
|
MochiKit.Async.callLater(0.1, MochiKit.Base.method(deferredResult, 'callback'));
|
||||||
}
|
}
|
||||||
@@ -2117,6 +2120,8 @@ Clipperz.log("THE BROWSER IS OFFLINE");
|
|||||||
|
|
||||||
this._mediaQueryStyle = newQueryStyle;
|
this._mediaQueryStyle = newQueryStyle;
|
||||||
|
|
||||||
|
MochiKit.DOM.setElementClass(document.body, newQueryStyle);
|
||||||
|
|
||||||
if (currentPage == 'cardDetailPage') {
|
if (currentPage == 'cardDetailPage') {
|
||||||
this.moveOutPage(this.currentPage(), 'mainPage');
|
this.moveOutPage(this.currentPage(), 'mainPage');
|
||||||
}
|
}
|
||||||
|
@@ -33,6 +33,23 @@ div.overlay {
|
|||||||
&.hidden {
|
&.hidden {
|
||||||
display: none;
|
display: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
&.card {
|
||||||
|
|
||||||
|
top: 48px;
|
||||||
|
|
||||||
|
.extra-wide & {
|
||||||
|
left: 46.6%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.wide & {
|
||||||
|
left: 33.3%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.narrow & {
|
||||||
|
left: 100%;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
z-index: 99999;
|
z-index: 99999;
|
||||||
position: fixed;
|
position: fixed;
|
||||||
@@ -45,6 +62,15 @@ div.overlay {
|
|||||||
background: rgba(0,0,0,0.8);
|
background: rgba(0,0,0,0.8);
|
||||||
@include border-radius(20px);
|
@include border-radius(20px);
|
||||||
|
|
||||||
|
&.card {
|
||||||
|
.extra-wide & {
|
||||||
|
left: 74%;
|
||||||
|
}
|
||||||
|
.wide & {
|
||||||
|
left: 66.6%;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
.title {
|
.title {
|
||||||
color: #FFF;
|
color: #FFF;
|
||||||
// font-family: "Helvetica Neue", Helvetica, Arial, "Lucida Grande", sans-serif;
|
// font-family: "Helvetica Neue", Helvetica, Arial, "Lucida Grande", sans-serif;
|
||||||
@@ -78,12 +104,16 @@ div.overlay {
|
|||||||
}
|
}
|
||||||
|
|
||||||
&.ios-overlay-show {
|
&.ios-overlay-show {
|
||||||
@include animation(ios-overlay-show, 750ms);
|
&:not(.card) {
|
||||||
|
@include animation(ios-overlay-show, 750ms);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
&.ios-overlay-hide {
|
&.ios-overlay-hide {
|
||||||
@include animation(ios-overlay-hide, 750ms, linear, 1, forwards);
|
&:not(.card) {
|
||||||
|
@include animation(ios-overlay-hide, 750ms, linear, 1, forwards);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// http://37signals.com/svn/posts/2577-loading-spinner-animation-using-css-and-webkit
|
// http://37signals.com/svn/posts/2577-loading-spinner-animation-using-css-and-webkit
|
||||||
|
新增問題並參考
封鎖使用者