mirror of
http://git.whoc.org.uk/git/password-manager.git
synced 2025-01-10 06:50:03 +01:00
Many small overall UI improvements
- proxy are now aware of their respective features; - updated account status info and added also proxy info (especially to show when using an offline copy) - conditionally enabled different features across the UI, based on user account / proxy available features
This commit is contained in:
parent
3d809a71db
commit
187959fd1e
@ -936,7 +936,7 @@ div.cardContent {
|
|||||||
overflow: auto;
|
overflow: auto;
|
||||||
z-index: 5;
|
z-index: 5;
|
||||||
box-shadow: 2px 0 6px 0 rgba(0, 0, 0, 0.1); }
|
box-shadow: 2px 0 6px 0 rgba(0, 0, 0, 0.1); }
|
||||||
div.cardContent div.cardListColumn.column div.cardList {
|
div.cardContent div.cardListColumn.column.addCard div.cardList {
|
||||||
padding-bottom: 100px; }
|
padding-bottom: 100px; }
|
||||||
div.cardContent div.cardListColumn.column div.addCardButton {
|
div.cardContent div.cardListColumn.column div.addCardButton {
|
||||||
font-family: 'clipperz-icons';
|
font-family: 'clipperz-icons';
|
||||||
@ -1935,32 +1935,35 @@ span.count {
|
|||||||
#extraFeaturesPanel > div ul li a.button:hover {
|
#extraFeaturesPanel > div ul li a.button:hover {
|
||||||
color: lightgrey; }
|
color: lightgrey; }
|
||||||
|
|
||||||
.accountStatus {
|
.miscInfo .proxyInfo {
|
||||||
background-color: green;
|
border-bottom: 1px solid white;
|
||||||
padding: 3px;
|
|
||||||
font-size: 10pt;
|
|
||||||
border-bottom: 1px solid white; }
|
|
||||||
.accountStatus.FULL {
|
|
||||||
display: none;
|
display: none;
|
||||||
visibility: hidden; }
|
visibility: hidden; }
|
||||||
.accountStatus.FULL.isExpiring {
|
.miscInfo .proxyInfo.OFFLINE_COPY {
|
||||||
|
display: block;
|
||||||
|
visibility: visible;
|
||||||
|
background-color: #1863a1;
|
||||||
|
color: white; }
|
||||||
|
.miscInfo .proxyInfo.OFFLINE_COPY .referenceDate {
|
||||||
|
padding-left: 10px; }
|
||||||
|
.miscInfo .accountStatus {
|
||||||
|
border-bottom: 1px solid white;
|
||||||
|
background-color: green;
|
||||||
|
padding: 3px;
|
||||||
|
font-size: 10pt; }
|
||||||
|
.miscInfo .accountStatus.FULL {
|
||||||
|
display: none;
|
||||||
|
visibility: hidden; }
|
||||||
|
.miscInfo .accountStatus.FULL.isExpiring {
|
||||||
display: block;
|
display: block;
|
||||||
visibility: visible;
|
visibility: visible;
|
||||||
background-color: yellow; }
|
background-color: yellow; }
|
||||||
.accountStatus.TRIAL {
|
.miscInfo .accountStatus.TRIAL {
|
||||||
background-color: orange; }
|
background-color: orange; }
|
||||||
.accountStatus.TRIAL.isExpiring {
|
.miscInfo .accountStatus.TRIAL.isExpiring {
|
||||||
background-color: red; }
|
background-color: red; }
|
||||||
.accountStatus.EXPIRED {
|
.miscInfo .accountStatus.EXPIRED {
|
||||||
background-color: red; }
|
background-color: red; }
|
||||||
.accountStatus.OFFLINE_COPY {
|
|
||||||
background-color: #1863a1;
|
|
||||||
color: white; }
|
|
||||||
.accountStatus.OFFLINE_COPY .expirationDate {
|
|
||||||
display: none;
|
|
||||||
visibility: hidden; }
|
|
||||||
.accountStatus.OFFLINE_COPY .referenceDate {
|
|
||||||
padding-left: 10px; }
|
|
||||||
|
|
||||||
div.cardList.loadingCard li.selected {
|
div.cardList.loadingCard li.selected {
|
||||||
background-color: gray; }
|
background-color: gray; }
|
||||||
|
File diff suppressed because one or more lines are too long
@ -4,28 +4,30 @@
|
|||||||
{
|
{
|
||||||
"icon": {
|
"icon": {
|
||||||
"paths": [
|
"paths": [
|
||||||
"M640.9 63.9c-141.4 0-256 114.6-256 256 0 19.6 2.2 38.6 6.4 56.9l-391.3 391.2v64l64 64h128l64-64v-64h64v-64h64v-64h128l70.8-70.8c18.7 4.3 38.1 6.6 58.1 6.6 141.4 0 256-114.6 256-256s-114.7-255.9-256-255.9zM384 512l-320 320v-64l320-320v64zM704 320c-35.3 0-64-28.7-64-64s28.7-64 64-64 64 28.7 64 64c0 35.3-28.7 64-64 64z"
|
"M704 0c-176.73 0-320 143.268-320 320 0 20.026 1.858 39.616 5.376 58.624l-389.376 389.376v192c0 35.346 28.654 64 64 64h64v-64h128v-128h128v-128h128l83.042-83.042c34.010 12.316 70.696 19.042 108.958 19.042 176.73 0 320-143.268 320-320s-143.27-320-320-320zM799.874 320.126c-53.020 0-96-42.98-96-96s42.98-96 96-96 96 42.98 96 96-42.98 96-96 96z"
|
||||||
],
|
],
|
||||||
"width": 896,
|
|
||||||
"attrs": [],
|
"attrs": [],
|
||||||
"isMulticolor": false,
|
"isMulticolor": false,
|
||||||
"tags": [
|
"tags": [
|
||||||
"key"
|
"key",
|
||||||
|
"password",
|
||||||
|
"login",
|
||||||
|
"signin"
|
||||||
],
|
],
|
||||||
"defaultCode": 61513,
|
"defaultCode": 57802,
|
||||||
"grid": 16
|
"grid": 16
|
||||||
},
|
},
|
||||||
"attrs": [],
|
"attrs": [],
|
||||||
"properties": {
|
"properties": {
|
||||||
"id": 91,
|
"id": 548,
|
||||||
"order": 23,
|
"order": 26,
|
||||||
"prevSize": 32,
|
"prevSize": 32,
|
||||||
"code": 61513,
|
"code": 59789,
|
||||||
"name": "key",
|
"ligatures": "generate password",
|
||||||
"ligatures": "generate password"
|
"name": "key"
|
||||||
},
|
},
|
||||||
"setIdx": 0,
|
"setIdx": 1,
|
||||||
"iconIdx": 91
|
"iconIdx": 141
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"icon": {
|
"icon": {
|
||||||
|
@ -131,6 +131,20 @@ Clipperz.PM.Proxy.prototype = MochiKit.Base.update(null, {
|
|||||||
|
|
||||||
//=========================================================================
|
//=========================================================================
|
||||||
|
|
||||||
|
'type': function () {
|
||||||
|
throw Clipperz.Base.exception.AbstractMethod;
|
||||||
|
},
|
||||||
|
|
||||||
|
'typeDescription': function () {
|
||||||
|
throw Clipperz.Base.exception.AbstractMethod;
|
||||||
|
},
|
||||||
|
|
||||||
|
'features': function (someFeatures) {
|
||||||
|
throw Clipperz.Base.exception.AbstractMethod;
|
||||||
|
},
|
||||||
|
|
||||||
|
//=========================================================================
|
||||||
|
|
||||||
'processMessage': function (aFunctionName, someParameters, aRequestType) {
|
'processMessage': function (aFunctionName, someParameters, aRequestType) {
|
||||||
var deferredResult;
|
var deferredResult;
|
||||||
|
|
||||||
|
@ -48,6 +48,20 @@ Clipperz.Base.extend(Clipperz.PM.Proxy.JSON, Clipperz.PM.Proxy, {
|
|||||||
|
|
||||||
//=========================================================================
|
//=========================================================================
|
||||||
|
|
||||||
|
'type': function () {
|
||||||
|
return 'ONLINE';
|
||||||
|
},
|
||||||
|
|
||||||
|
'typeDescription': function () {
|
||||||
|
return 'Online service';
|
||||||
|
},
|
||||||
|
|
||||||
|
'features': function (someFeatures) {
|
||||||
|
return someFeatures;
|
||||||
|
},
|
||||||
|
|
||||||
|
//=========================================================================
|
||||||
|
|
||||||
'_sendMessage': function(aFunctionName, aVersion, someParameters) {
|
'_sendMessage': function(aFunctionName, aVersion, someParameters) {
|
||||||
var deferredResult;
|
var deferredResult;
|
||||||
var parameters;
|
var parameters;
|
||||||
|
@ -21,6 +21,7 @@ refer to http://www.clipperz.com.
|
|||||||
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
if (typeof(Clipperz) == 'undefined') { Clipperz = {}; }
|
if (typeof(Clipperz) == 'undefined') { Clipperz = {}; }
|
||||||
if (typeof(Clipperz.PM) == 'undefined') { Clipperz.PM = {}; }
|
if (typeof(Clipperz.PM) == 'undefined') { Clipperz.PM = {}; }
|
||||||
|
|
||||||
@ -32,6 +33,8 @@ Clipperz.PM.Proxy.Offline = function(args) {
|
|||||||
Clipperz.PM.Proxy.Offline.superclass.constructor.call(this, args);
|
Clipperz.PM.Proxy.Offline.superclass.constructor.call(this, args);
|
||||||
|
|
||||||
this._dataStore = args.dataStore || new Clipperz.PM.Proxy.Offline.DataStore(args);
|
this._dataStore = args.dataStore || new Clipperz.PM.Proxy.Offline.DataStore(args);
|
||||||
|
this._type = args.type || 'OFFLINE';
|
||||||
|
this._typeDescription = args.typeDescription || 'Offline';
|
||||||
|
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
@ -64,7 +67,29 @@ Clipperz.Base.extend(Clipperz.PM.Proxy.Offline, Clipperz.PM.Proxy, {
|
|||||||
return this.dataStore().canRegisterNewUsers();
|
return this.dataStore().canRegisterNewUsers();
|
||||||
},
|
},
|
||||||
|
|
||||||
//-------------------------------------------------------------------------
|
//=========================================================================
|
||||||
|
|
||||||
|
'type': function () {
|
||||||
|
return this._type;
|
||||||
|
},
|
||||||
|
|
||||||
|
'typeDescription': function () {
|
||||||
|
return this._typeDescription;
|
||||||
|
},
|
||||||
|
|
||||||
|
'features': function (someFeatures) {
|
||||||
|
var result;
|
||||||
|
|
||||||
|
if (this.type() == 'OFFLINE_COPY') {
|
||||||
|
result = ['LIST_CARDS', 'CARD_DETAILS'];
|
||||||
|
} else {
|
||||||
|
result = someFeatures;
|
||||||
|
}
|
||||||
|
|
||||||
|
return result;
|
||||||
|
},
|
||||||
|
|
||||||
|
//=========================================================================
|
||||||
|
|
||||||
__syntaxFix__: "syntax fix"
|
__syntaxFix__: "syntax fix"
|
||||||
|
|
||||||
|
@ -21,6 +21,7 @@ refer to http://www.clipperz.com.
|
|||||||
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
"use strict";
|
||||||
Clipperz.Base.module('Clipperz.PM.UI.Components');
|
Clipperz.Base.module('Clipperz.PM.UI.Components');
|
||||||
|
|
||||||
Clipperz.PM.UI.Components.AccountStatus = React.createClass({
|
Clipperz.PM.UI.Components.AccountStatus = React.createClass({
|
||||||
@ -28,7 +29,9 @@ Clipperz.PM.UI.Components.AccountStatus = React.createClass({
|
|||||||
propTypes: {
|
propTypes: {
|
||||||
// 'currentSubscriptionType': React.PropTypes.oneOf(['EARLY_ADOPTER', 'FRIEND', 'FAN', 'DEVOTEE', 'PATRON', 'TRIAL', 'TRIAL_EXPIRED', 'PAYMENT_FAILED_2', 'EXPIRED', 'PAYMENT_FAILED', 'VERIFYING_PAYMENT', 'VERIFYING_PAYMENT_2']).isRequired,
|
// 'currentSubscriptionType': React.PropTypes.oneOf(['EARLY_ADOPTER', 'FRIEND', 'FAN', 'DEVOTEE', 'PATRON', 'TRIAL', 'TRIAL_EXPIRED', 'PAYMENT_FAILED_2', 'EXPIRED', 'PAYMENT_FAILED', 'VERIFYING_PAYMENT', 'VERIFYING_PAYMENT_2']).isRequired,
|
||||||
'expirationDate': React.PropTypes.string /* .isRequired */,
|
'expirationDate': React.PropTypes.string /* .isRequired */,
|
||||||
|
'referenceDate': React.PropTypes.string /* .isRequired */,
|
||||||
'featureSet': React.PropTypes.oneOf(['TRIAL', 'EXPIRED', 'FULL']) /* .isRequired */ ,
|
'featureSet': React.PropTypes.oneOf(['TRIAL', 'EXPIRED', 'FULL']) /* .isRequired */ ,
|
||||||
|
'proxyType': React.PropTypes.oneOf(['ONLINE', 'OFFLINE', 'OFFLINE_COPY']),
|
||||||
'isExpired': React.PropTypes.bool /* .isRequired */ ,
|
'isExpired': React.PropTypes.bool /* .isRequired */ ,
|
||||||
'isExpiring': React.PropTypes.bool /* .isRequired */ ,
|
'isExpiring': React.PropTypes.bool /* .isRequired */ ,
|
||||||
'paymentVerificationPending': React.PropTypes.bool /* .isRequired */ ,
|
'paymentVerificationPending': React.PropTypes.bool /* .isRequired */ ,
|
||||||
@ -38,18 +41,30 @@ Clipperz.PM.UI.Components.AccountStatus = React.createClass({
|
|||||||
|
|
||||||
render: function () {
|
render: function () {
|
||||||
//console.log("AccountStatus props", this.props);
|
//console.log("AccountStatus props", this.props);
|
||||||
var classes = {
|
var accountInfoClasses = {
|
||||||
'accountStatus': true,
|
'accountStatus': true,
|
||||||
'isExpiring': this.props['isExpiring'],
|
'isExpiring': this.props['isExpiring'],
|
||||||
'isExpired': this.props['isExpired'],
|
'isExpired': this.props['isExpired'],
|
||||||
};
|
};
|
||||||
|
accountInfoClasses[this.props['featureSet']] = true;
|
||||||
|
|
||||||
classes[this.props['featureSet']] = true;
|
var proxyInfoClasses = {
|
||||||
|
'proxyInfo': true
|
||||||
|
}
|
||||||
|
proxyInfoClasses[this.props['proxyType']] = true;
|
||||||
|
|
||||||
return React.DOM.div({'className':React.addons.classSet(classes)}, [
|
return React.DOM.div({'className':'miscInfo'}, [
|
||||||
React.DOM.span({'className': 'level'}, this.props['featureSet']),
|
React.DOM.div({'className':React.addons.classSet(proxyInfoClasses)}, [
|
||||||
|
React.DOM.span({'className':'proxyDescription'}, this.props['proxyTypeDescription']),
|
||||||
|
React.DOM.span({'className':'referenceDate'}, this.props['referenceDate'])
|
||||||
|
]),
|
||||||
|
React.DOM.div({'className':React.addons.classSet(accountInfoClasses)}, [
|
||||||
|
React.DOM.span({'className':'level'}, Clipperz.PM.DataModel.Feature['featureSets'][this.props['featureSet']]),
|
||||||
|
React.DOM.span({'className':'expirationMessage'}, "expiring on"),
|
||||||
React.DOM.span({'className':'expirationDate'}, this.props['expirationDate'])
|
React.DOM.span({'className':'expirationDate'}, this.props['expirationDate'])
|
||||||
|
])
|
||||||
]);
|
]);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//=========================================================================
|
//=========================================================================
|
||||||
|
@ -30,6 +30,7 @@ Clipperz.PM.UI.Components.CardToolbar = React.createClass({
|
|||||||
'style': React.PropTypes.oneOf(Clipperz_PM_UI_availableStyles).isRequired,
|
'style': React.PropTypes.oneOf(Clipperz_PM_UI_availableStyles).isRequired,
|
||||||
'enableSidePanels': React.PropTypes.bool.isRequired,
|
'enableSidePanels': React.PropTypes.bool.isRequired,
|
||||||
'accountInfo': React.PropTypes.object.isRequired,
|
'accountInfo': React.PropTypes.object.isRequired,
|
||||||
|
'proxyInfo': React.PropTypes.object.isRequired,
|
||||||
'messageBox': React.PropTypes.object.isRequired,
|
'messageBox': React.PropTypes.object.isRequired,
|
||||||
'filter': React.PropTypes.object /*.isRequired */
|
'filter': React.PropTypes.object /*.isRequired */
|
||||||
},
|
},
|
||||||
@ -99,7 +100,7 @@ Clipperz.PM.UI.Components.CardToolbar = React.createClass({
|
|||||||
return React.DOM.div({className:'cardToolbar ' + this.props['style']}, [
|
return React.DOM.div({className:'cardToolbar ' + this.props['style']}, [
|
||||||
// React.DOM.div({className:'header'}, this.props['enableSidePanels'] ? this.renderWithSidePanels() : this.renderWithoutSidePanels()),
|
// React.DOM.div({className:'header'}, this.props['enableSidePanels'] ? this.renderWithSidePanels() : this.renderWithoutSidePanels()),
|
||||||
React.DOM.header({}, this.props['enableSidePanels'] ? this.renderWithSidePanels() : this.renderWithoutSidePanels()),
|
React.DOM.header({}, this.props['enableSidePanels'] ? this.renderWithSidePanels() : this.renderWithoutSidePanels()),
|
||||||
Clipperz.PM.UI.Components.AccountStatus(this.props['accountInfo']),
|
Clipperz.PM.UI.Components.AccountStatus(MochiKit.Base.update(this.props['accountInfo'], this.props['proxyInfo'])),
|
||||||
Clipperz.PM.UI.Components.MessageBox(this.props['messageBox']),
|
Clipperz.PM.UI.Components.MessageBox(this.props['messageBox']),
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
@ -31,6 +31,15 @@ Clipperz.PM.UI.Components.Cards.CommandToolbar = React.createClass({
|
|||||||
propTypes: {
|
propTypes: {
|
||||||
// 'label': React.PropTypes.string.isRequired,
|
// 'label': React.PropTypes.string.isRequired,
|
||||||
// 'loading': React.PropTypes.bool,
|
// 'loading': React.PropTypes.bool,
|
||||||
|
'features': React.PropTypes.array.isRequired,
|
||||||
|
},
|
||||||
|
|
||||||
|
features: function () {
|
||||||
|
return this.props['features'];
|
||||||
|
},
|
||||||
|
|
||||||
|
isFeatureEnabled: function (aValue) {
|
||||||
|
return (this.features().indexOf(aValue) > -1);
|
||||||
},
|
},
|
||||||
|
|
||||||
//----------------------------------------------------------------------------
|
//----------------------------------------------------------------------------
|
||||||
@ -40,29 +49,17 @@ Clipperz.PM.UI.Components.Cards.CommandToolbar = React.createClass({
|
|||||||
},
|
},
|
||||||
|
|
||||||
//----------------------------------------------------------------------------
|
//----------------------------------------------------------------------------
|
||||||
|
// EDIT_CARD -> archive, edit
|
||||||
|
// DELETE_CARD -> delete
|
||||||
|
// ADD_CARD -> clone
|
||||||
commands: function () {
|
commands: function () {
|
||||||
|
var archiveLabel = this.props['_isArchived'] ? "restore" : "archive";
|
||||||
return {
|
return {
|
||||||
'delete': {
|
'delete': { 'label': "delete", 'broadcastEvent': 'deleteCard', 'enabled': this.isFeatureEnabled('DELETE_CARD')},
|
||||||
'label': "delete",
|
'archive': { 'label': archiveLabel, 'broadcastEvent': 'toggleArchiveCard', 'enabled': this.isFeatureEnabled('EDIT_CARD')},
|
||||||
'broadcastEvent': 'deleteCard'
|
// 'share': { 'label': "share", 'broadcastEvent': 'shareCard' },
|
||||||
},
|
'clone': { 'label': "clone", 'broadcastEvent': 'cloneCard', 'enabled': this.isFeatureEnabled('ADD_CARD')},
|
||||||
'archive': {
|
'edit': { 'label': "edit", 'broadcastEvent': 'editCard', 'enabled': this.isFeatureEnabled('EDIT_CARD')}
|
||||||
'label': this.props['_isArchived'] ? "restore" : "archive",
|
|
||||||
'broadcastEvent': 'toggleArchiveCard'
|
|
||||||
},
|
|
||||||
// 'share': {
|
|
||||||
// 'label': "share",
|
|
||||||
// 'broadcastEvent': 'shareCard'
|
|
||||||
// },
|
|
||||||
'clone': {
|
|
||||||
'label': "clone",
|
|
||||||
'broadcastEvent': 'cloneCard'
|
|
||||||
},
|
|
||||||
'edit': {
|
|
||||||
'label': "edit",
|
|
||||||
'broadcastEvent': 'editCard'
|
|
||||||
}
|
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -92,7 +89,12 @@ Clipperz.PM.UI.Components.Cards.CommandToolbar = React.createClass({
|
|||||||
}
|
}
|
||||||
|
|
||||||
return React.DOM.ul({}, MochiKit.Base.map(function (aCommand) {
|
return React.DOM.ul({}, MochiKit.Base.map(function (aCommand) {
|
||||||
return React.DOM.li({'className':aCommand['broadcastEvent'], 'onClick':commandHandler, 'data-broadcast-event':aCommand['broadcastEvent']}, [React.DOM.span({}, aCommand['label'])]);
|
var classes = {};
|
||||||
|
classes[aCommand['broadcastEvent']] = true;
|
||||||
|
classes['enabled'] = aCommand['enabled'];
|
||||||
|
classes['disabled'] = !aCommand['enabled'];
|
||||||
|
|
||||||
|
return React.DOM.li({'className':React.addons.classSet(classes), 'onClick':aCommand['enabled'] ? commandHandler : null, 'data-broadcast-event':aCommand['broadcastEvent']}, [React.DOM.span({}, aCommand['label'])]);
|
||||||
}, commandValues));
|
}, commandValues));
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -34,6 +34,7 @@ Clipperz.PM.UI.Components.Cards.Detail = React.createClass({
|
|||||||
|
|
||||||
result = this.props['selectedCard'];
|
result = this.props['selectedCard'];
|
||||||
if (result) {
|
if (result) {
|
||||||
|
result['features'] = this.props['features'];
|
||||||
result['style'] = this.props['style'];
|
result['style'] = this.props['style'];
|
||||||
result['ask'] = (this.props['style'] == 'narrow') ? this.props['ask'] : null;
|
result['ask'] = (this.props['style'] == 'narrow') ? this.props['ask'] : null;
|
||||||
result['showGlobalMask'] = this.props['showGlobalMask'];
|
result['showGlobalMask'] = this.props['showGlobalMask'];
|
||||||
|
@ -30,12 +30,23 @@ Clipperz.PM.UI.Components.Cards.List = React.createClass({
|
|||||||
|
|
||||||
propTypes: {
|
propTypes: {
|
||||||
'cards': React.PropTypes.array,
|
'cards': React.PropTypes.array,
|
||||||
'featureSet': React.PropTypes.oneOf(['FULL', 'EXPIRED', 'TRIAL', 'OFFLINE']).isRequired,
|
'featureSet': React.PropTypes.oneOf(['FULL', 'EXPIRED', 'TRIAL']).isRequired,
|
||||||
|
'features': React.PropTypes.array.isRequired,
|
||||||
'selectedCard': React.PropTypes.object
|
'selectedCard': React.PropTypes.object
|
||||||
},
|
},
|
||||||
|
|
||||||
|
features: function () {
|
||||||
|
return this.props['features'];
|
||||||
|
},
|
||||||
|
|
||||||
|
isFeatureEnabled: function (aValue) {
|
||||||
|
return (this.features().indexOf(aValue) > -1);
|
||||||
|
},
|
||||||
|
|
||||||
handleClick: function (anEvent) {
|
handleClick: function (anEvent) {
|
||||||
|
if (this.isFeatureEnabled('CARD_DETAILS')) {
|
||||||
MochiKit.Signal.signal(Clipperz.Signal.NotificationCenter, 'selectCard', {'reference':anEvent.currentTarget.dataset.reference, 'label':anEvent.currentTarget.dataset.label}, true);
|
MochiKit.Signal.signal(Clipperz.Signal.NotificationCenter, 'selectCard', {'reference':anEvent.currentTarget.dataset.reference, 'label':anEvent.currentTarget.dataset.label}, true);
|
||||||
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
renderItem: function (anItem) {
|
renderItem: function (anItem) {
|
||||||
@ -70,7 +81,7 @@ Clipperz.PM.UI.Components.Cards.List = React.createClass({
|
|||||||
classes[this.props['style']] = true;
|
classes[this.props['style']] = true;
|
||||||
|
|
||||||
return React.DOM.div({'key':'cardList', 'className':React.addons.classSet(classes)}, [
|
return React.DOM.div({'key':'cardList', 'className':React.addons.classSet(classes)}, [
|
||||||
React.DOM.ul({}, MochiKit.Base.map(this.renderItem, cards))
|
this.isFeatureEnabled('LIST_CARDS') ? React.DOM.ul({}, MochiKit.Base.map(this.renderItem, cards)) : null
|
||||||
]);
|
]);
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -62,7 +62,6 @@ Clipperz.PM.UI.Components.Cards.View = React.createClass({
|
|||||||
newState[aField['_reference']] = !this.state[aField['_reference']];
|
newState[aField['_reference']] = !this.state[aField['_reference']];
|
||||||
|
|
||||||
return function () {
|
return function () {
|
||||||
console.log("SHOW PASSWORD", aField, self);
|
|
||||||
self.setState(newState);
|
self.setState(newState);
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
|
@ -26,7 +26,7 @@ Clipperz.Base.module('Clipperz.PM.UI.Components');
|
|||||||
Clipperz.PM.UI.Components.ExpiredPanel = React.createClass({
|
Clipperz.PM.UI.Components.ExpiredPanel = React.createClass({
|
||||||
|
|
||||||
propTypes: {
|
propTypes: {
|
||||||
// featureSet: React.PropTypes.oneOf(['FULL', 'EXPIRED', 'TRIAL', 'OFFLINE']).isRequired,
|
// featureSet: React.PropTypes.oneOf(['FULL', 'EXPIRED', 'TRIAL']).isRequired,
|
||||||
// 'level': React.PropTypes.oneOf(['hide', 'info', 'warning', 'error']).isRequired
|
// 'level': React.PropTypes.oneOf(['hide', 'info', 'warning', 'error']).isRequired
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -28,7 +28,8 @@ Clipperz.PM.UI.Components.Pages.MainPage = React.createClass({
|
|||||||
|
|
||||||
getDefaultProps: function () {
|
getDefaultProps: function () {
|
||||||
return {
|
return {
|
||||||
featureSet: 'FULL'
|
featureSet: 'FULL',
|
||||||
|
features: []
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -36,7 +37,8 @@ Clipperz.PM.UI.Components.Pages.MainPage = React.createClass({
|
|||||||
'tags': React.PropTypes.object,
|
'tags': React.PropTypes.object,
|
||||||
'allTags': React.PropTypes.array,
|
'allTags': React.PropTypes.array,
|
||||||
'messageBox': React.PropTypes.object.isRequired,
|
'messageBox': React.PropTypes.object.isRequired,
|
||||||
'featureSet': React.PropTypes.oneOf(['FULL', 'EXPIRED', 'TRIAL', 'OFFLINE']).isRequired,
|
'featureSet': React.PropTypes.oneOf(['FULL', 'EXPIRED', 'TRIAL']).isRequired,
|
||||||
|
'features': React.PropTypes.array.isRequired,
|
||||||
'accountInfo': React.PropTypes.object.isRequired,
|
'accountInfo': React.PropTypes.object.isRequired,
|
||||||
// 'mediaQueryStyle': React.PropTypes.oneOf(['extra-short', 'narrow', 'wide', 'extra-wide']).isRequired,
|
// 'mediaQueryStyle': React.PropTypes.oneOf(['extra-short', 'narrow', 'wide', 'extra-wide']).isRequired,
|
||||||
'style': React.PropTypes.oneOf(Clipperz_PM_UI_availableStyles).isRequired,
|
'style': React.PropTypes.oneOf(Clipperz_PM_UI_availableStyles).isRequired,
|
||||||
|
@ -90,6 +90,12 @@ Clipperz.PM.UI.Components.Panels.ExtraFeaturesPanel = React.createClass({
|
|||||||
React.DOM.p({}, "")
|
React.DOM.p({}, "")
|
||||||
])
|
])
|
||||||
]),
|
]),
|
||||||
|
React.DOM.li({}, [
|
||||||
|
React.DOM.h2({}, "Device PIN"),
|
||||||
|
React.DOM.div({}, [
|
||||||
|
React.DOM.p({}, "Configure a PIN that will allow to get access to your cards, but only on this device.")
|
||||||
|
])
|
||||||
|
]),
|
||||||
React.DOM.li({}, [
|
React.DOM.li({}, [
|
||||||
React.DOM.h2({}, "Preferences"),
|
React.DOM.h2({}, "Preferences"),
|
||||||
React.DOM.div({}, [
|
React.DOM.div({}, [
|
||||||
|
@ -31,7 +31,8 @@ Clipperz.PM.UI.Components.Panels.MainPanel = React.createClass({
|
|||||||
propTypes: {
|
propTypes: {
|
||||||
'allTags': React.PropTypes.array,
|
'allTags': React.PropTypes.array,
|
||||||
'messageBox': React.PropTypes.object.isRequired,
|
'messageBox': React.PropTypes.object.isRequired,
|
||||||
'featureSet': React.PropTypes.oneOf(['FULL', 'EXPIRED', 'TRIAL', 'OFFLINE']).isRequired,
|
'featureSet': React.PropTypes.oneOf(['FULL', 'EXPIRED', 'TRIAL']).isRequired,
|
||||||
|
'features': React.PropTypes.array.isRequired,
|
||||||
'style': React.PropTypes.oneOf(Clipperz_PM_UI_availableStyles).isRequired,
|
'style': React.PropTypes.oneOf(Clipperz_PM_UI_availableStyles).isRequired,
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -43,6 +44,14 @@ Clipperz.PM.UI.Components.Panels.MainPanel = React.createClass({
|
|||||||
return this.props['featureSet'];
|
return this.props['featureSet'];
|
||||||
},
|
},
|
||||||
|
|
||||||
|
features: function () {
|
||||||
|
return this.props['features'];
|
||||||
|
},
|
||||||
|
|
||||||
|
isFeatureEnabled: function (aValue) {
|
||||||
|
return (this.features().indexOf(aValue) > -1);
|
||||||
|
},
|
||||||
|
|
||||||
handleMaskClick: function () {
|
handleMaskClick: function () {
|
||||||
MochiKit.Signal.signal(Clipperz.Signal.NotificationCenter, 'maskClick');
|
MochiKit.Signal.signal(Clipperz.Signal.NotificationCenter, 'maskClick');
|
||||||
},
|
},
|
||||||
@ -62,15 +71,22 @@ Clipperz.PM.UI.Components.Panels.MainPanel = React.createClass({
|
|||||||
|
|
||||||
renderCardFrame: function (firstColumnComponents, secondColumnComponents) {
|
renderCardFrame: function (firstColumnComponents, secondColumnComponents) {
|
||||||
var addCardButton;
|
var addCardButton;
|
||||||
|
var cardColumnClasses;
|
||||||
|
|
||||||
if ((this.props['featureSet'] != 'EXPIRED') && (this.props['featureSet'] != 'OFFLINE')) {
|
// if ((this.props['featureSet'] != 'EXPIRED') && (this.props['featureSet'] != 'OFFLINE')) {
|
||||||
|
if (this.isFeatureEnabled('ADD_CARD')) {
|
||||||
addCardButton = React.DOM.div({'className': 'addCardButton', 'onClick':this.handleAddCardClick}, 'add card');
|
addCardButton = React.DOM.div({'className': 'addCardButton', 'onClick':this.handleAddCardClick}, 'add card');
|
||||||
} else {
|
} else {
|
||||||
addCardButton = null;
|
addCardButton = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
cardColumnClasses = {
|
||||||
|
'cardListColumn': true,
|
||||||
|
'column': true,
|
||||||
|
'addCard': this.isFeatureEnabled('ADD_CARD')
|
||||||
|
}
|
||||||
return React.DOM.div({'key':'cardContent', 'className':'cardContent'}, [
|
return React.DOM.div({'key':'cardContent', 'className':'cardContent'}, [
|
||||||
React.DOM.div({'className':'cardListColumn column'}, [addCardButton, firstColumnComponents]),
|
React.DOM.div({'className':React.addons.classSet(cardColumnClasses)}, [addCardButton, firstColumnComponents]),
|
||||||
React.DOM.div({'className':'cardDetail column right'}, secondColumnComponents)
|
React.DOM.div({'className':'cardDetail column right'}, secondColumnComponents)
|
||||||
])
|
])
|
||||||
},
|
},
|
||||||
|
@ -462,6 +462,7 @@ console.log("THE BROWSER IS OFFLINE");
|
|||||||
|
|
||||||
showCardDetailInNarrowView: function (aValue) {
|
showCardDetailInNarrowView: function (aValue) {
|
||||||
return Clipperz.Async.callbacks("MainController.showCardDetailInNarrowView", [
|
return Clipperz.Async.callbacks("MainController.showCardDetailInNarrowView", [
|
||||||
|
MochiKit.Base.method(this, 'setPageProperties', 'cardDetailPage', 'features', this.features()),
|
||||||
MochiKit.Base.method(this, 'setPageProperties', 'cardDetailPage', 'selectedCard', aValue),
|
MochiKit.Base.method(this, 'setPageProperties', 'cardDetailPage', 'selectedCard', aValue),
|
||||||
MochiKit.Base.method(this, 'moveInPage', this.currentPage(), 'cardDetailPage'),
|
MochiKit.Base.method(this, 'moveInPage', this.currentPage(), 'cardDetailPage'),
|
||||||
], {trace:false});
|
], {trace:false});
|
||||||
@ -581,7 +582,6 @@ console.log("THE BROWSER IS OFFLINE");
|
|||||||
var fullFilterCriteria;
|
var fullFilterCriteria;
|
||||||
var selectedCardReference = this._selectedCardInfo ? this._selectedCardInfo['reference'] : null;
|
var selectedCardReference = this._selectedCardInfo ? this._selectedCardInfo['reference'] : null;
|
||||||
|
|
||||||
//console.log("updateSelectedCards - ACCOUNT INFO.featureSet", this.userAccountInfo()['featureSet']);
|
|
||||||
if (aFilter['type'] == 'ALL') {
|
if (aFilter['type'] == 'ALL') {
|
||||||
filterCriteria = MochiKit.Base.operator.truth;
|
filterCriteria = MochiKit.Base.operator.truth;
|
||||||
sortCriteria = Clipperz.Base.caseInsensitiveKeyComparator('label');
|
sortCriteria = Clipperz.Base.caseInsensitiveKeyComparator('label');
|
||||||
@ -896,25 +896,17 @@ console.log("THE BROWSER IS OFFLINE");
|
|||||||
|
|
||||||
//-------------------------------------------------------------------------
|
//-------------------------------------------------------------------------
|
||||||
|
|
||||||
messageBoxContent: function () {
|
featureSet: function () {
|
||||||
var message;
|
return this.userAccountInfo()['featureSet'];
|
||||||
var level;
|
|
||||||
|
|
||||||
message = "";
|
|
||||||
level = 'HIDE';
|
|
||||||
|
|
||||||
//console.log("messageBox - this.user()", this.user());
|
|
||||||
if (this.userAccountInfo()['featureSet'] == 'EXPIRED') {
|
|
||||||
message = "Exprired subscription";
|
|
||||||
level = 'ERROR';
|
|
||||||
}
|
|
||||||
|
|
||||||
return {
|
|
||||||
'message': message,
|
|
||||||
'level': level
|
|
||||||
};
|
|
||||||
},
|
},
|
||||||
|
|
||||||
|
features: function () {
|
||||||
|
// return this.userAccountInfo()['features'];
|
||||||
|
return Clipperz.PM.Proxy.defaultProxy.features(this.userAccountInfo()['features']);
|
||||||
|
},
|
||||||
|
|
||||||
|
//.........................................................................
|
||||||
|
|
||||||
userAccountInfo: function () {
|
userAccountInfo: function () {
|
||||||
var result;
|
var result;
|
||||||
|
|
||||||
@ -924,6 +916,7 @@ console.log("THE BROWSER IS OFFLINE");
|
|||||||
var usefulFields = [
|
var usefulFields = [
|
||||||
'currentSubscriptionType',
|
'currentSubscriptionType',
|
||||||
'expirationDate',
|
'expirationDate',
|
||||||
|
'referenceDate',
|
||||||
'featureSet',
|
'featureSet',
|
||||||
'features',
|
'features',
|
||||||
'isExpired',
|
'isExpired',
|
||||||
@ -940,6 +933,34 @@ console.log("THE BROWSER IS OFFLINE");
|
|||||||
return result;
|
return result;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
proxyInfo: function () {
|
||||||
|
return {
|
||||||
|
'proxyType': Clipperz.PM.Proxy.defaultProxy.type(),
|
||||||
|
'proxyTypeDescription': Clipperz.PM.Proxy.defaultProxy.typeDescription()
|
||||||
|
}
|
||||||
|
|
||||||
|
},
|
||||||
|
//-------------------------------------------------------------------------
|
||||||
|
|
||||||
|
messageBoxContent: function () {
|
||||||
|
var message;
|
||||||
|
var level;
|
||||||
|
|
||||||
|
message = "";
|
||||||
|
level = 'HIDE';
|
||||||
|
|
||||||
|
//console.log("messageBox - this.user()", this.user());
|
||||||
|
if (this.featureSet() == 'EXPIRED') {
|
||||||
|
message = "Exprired subscription";
|
||||||
|
level = 'ERROR';
|
||||||
|
}
|
||||||
|
|
||||||
|
return {
|
||||||
|
'message': message,
|
||||||
|
'level': level
|
||||||
|
};
|
||||||
|
},
|
||||||
|
|
||||||
genericPageProperties: function () {
|
genericPageProperties: function () {
|
||||||
return {
|
return {
|
||||||
'style': this.mediaQueryStyle(),
|
'style': this.mediaQueryStyle(),
|
||||||
@ -968,7 +989,9 @@ console.log("THE BROWSER IS OFFLINE");
|
|||||||
'accountInfo': this.userAccountInfo(),
|
'accountInfo': this.userAccountInfo(),
|
||||||
'selectionPanelStatus': this.isSelectionPanelOpen() ? 'OPEN' : 'CLOSED',
|
'selectionPanelStatus': this.isSelectionPanelOpen() ? 'OPEN' : 'CLOSED',
|
||||||
'settingsPanelStatus': this.isSettingsPanelOpen() ? 'OPEN' : 'CLOSED',
|
'settingsPanelStatus': this.isSettingsPanelOpen() ? 'OPEN' : 'CLOSED',
|
||||||
'featureSet': this.userAccountInfo()['featureSet'],
|
'featureSet': this.featureSet(),
|
||||||
|
'features': this.features(),
|
||||||
|
'proxyInfo': this.proxyInfo(),
|
||||||
// 'shouldIncludeArchivedCards': this.shouldIncludeArchivedCards(),
|
// 'shouldIncludeArchivedCards': this.shouldIncludeArchivedCards(),
|
||||||
// 'cards': …,
|
// 'cards': …,
|
||||||
// 'tags': …,
|
// 'tags': …,
|
||||||
@ -1156,7 +1179,7 @@ console.log("THE BROWSER IS OFFLINE");
|
|||||||
selectCard: function (someInfo, shouldUpdateCardDetail) {
|
selectCard: function (someInfo, shouldUpdateCardDetail) {
|
||||||
var result;
|
var result;
|
||||||
|
|
||||||
if (this.userAccountInfo()['featureSet'] != 'EXPIRED') {
|
if (this.featureSet() != 'EXPIRED') {
|
||||||
this._selectedCardInfo = someInfo;
|
this._selectedCardInfo = someInfo;
|
||||||
this.refreshSelectedCards();
|
this.refreshSelectedCards();
|
||||||
result = this.updateSelectedCard(someInfo, true, shouldUpdateCardDetail);
|
result = this.updateSelectedCard(someInfo, true, shouldUpdateCardDetail);
|
||||||
|
@ -263,11 +263,9 @@ div.cardContent {
|
|||||||
div.cardToolbar.narrow {
|
div.cardToolbar.narrow {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
&.addCard {
|
||||||
div.cardList {
|
div.cardList {
|
||||||
// overflow-y: scroll;
|
|
||||||
padding-bottom: 100px;
|
padding-bottom: 100px;
|
||||||
|
|
||||||
ul {
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,8 +1,27 @@
|
|||||||
|
.miscInfo {
|
||||||
|
.proxyInfo {
|
||||||
|
border-bottom: 1px solid white;
|
||||||
|
display: none;
|
||||||
|
visibility: hidden;
|
||||||
|
|
||||||
|
&.OFFLINE_COPY {
|
||||||
|
display:block;
|
||||||
|
visibility: visible;
|
||||||
|
|
||||||
|
background-color: $clipperz-blue;
|
||||||
|
color: white;
|
||||||
|
|
||||||
|
.referenceDate {
|
||||||
|
padding-left: 10px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
.accountStatus {
|
.accountStatus {
|
||||||
|
border-bottom: 1px solid white;
|
||||||
background-color: green;
|
background-color: green;
|
||||||
padding: 3px;
|
padding: 3px;
|
||||||
font-size: 10pt;
|
font-size: 10pt;
|
||||||
border-bottom: 1px solid white;
|
|
||||||
|
|
||||||
&.FULL {
|
&.FULL {
|
||||||
display: none;
|
display: none;
|
||||||
@ -27,18 +46,5 @@
|
|||||||
&.EXPIRED {
|
&.EXPIRED {
|
||||||
background-color: red;
|
background-color: red;
|
||||||
}
|
}
|
||||||
|
|
||||||
&.OFFLINE_COPY {
|
|
||||||
background-color: $clipperz-blue;
|
|
||||||
color: white;
|
|
||||||
|
|
||||||
.expirationDate {
|
|
||||||
display: none;
|
|
||||||
visibility: hidden;
|
|
||||||
}
|
|
||||||
|
|
||||||
.referenceDate {
|
|
||||||
padding-left: 10px;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user