mirror of
http://git.whoc.org.uk/git/password-manager.git
synced 2025-01-11 07:20:03 +01:00
Fixes to release developer preview of the /delta version
/delta needs an updated backend to support its payment options. /beta and /gamma have been updated to be compatible with the new backend.
This commit is contained in:
parent
093d5e7965
commit
b3967dae52
2
.gitignore
vendored
2
.gitignore
vendored
@ -2,3 +2,5 @@ target
|
|||||||
*.pyc
|
*.pyc
|
||||||
backend/java
|
backend/java
|
||||||
scripts/builder/backends/javaBuilder.py
|
scripts/builder/backends/javaBuilder.py
|
||||||
|
scripts/btcTranfer
|
||||||
|
scripts/deltaDeploy
|
@ -316,9 +316,9 @@ Clipperz.Crypto.PRNG.CryptoRandomRandomnessSource.prototype = MochiKit.Base.upda
|
|||||||
var bytesToCollect;
|
var bytesToCollect;
|
||||||
|
|
||||||
if (this.boostMode() == true) {
|
if (this.boostMode() == true) {
|
||||||
bytesToCollect = 64;
|
|
||||||
} else {
|
|
||||||
bytesToCollect = 8;
|
bytesToCollect = 8;
|
||||||
|
} else {
|
||||||
|
bytesToCollect = 32;
|
||||||
}
|
}
|
||||||
|
|
||||||
var randomValuesArray = new Uint8Array(bytesToCollect);
|
var randomValuesArray = new Uint8Array(bytesToCollect);
|
||||||
|
@ -107,7 +107,7 @@ Clipperz_normalizedNewLine = '\x0d\x0a';
|
|||||||
/*offline_data_placeholder*/
|
/*offline_data_placeholder*/
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<!-- div class="testBlock">
|
<div class="testBlock">
|
||||||
<script type="text/javascript" src="./js/TestData/User.data.js" charset="utf-8"></script>
|
<script type="text/javascript" src="./js/TestData/User.data.js" charset="utf-8"></script>
|
||||||
<script>
|
<script>
|
||||||
var dataStore = new Clipperz.PM.Proxy.Offline.DataStore({
|
var dataStore = new Clipperz.PM.Proxy.Offline.DataStore({
|
||||||
@ -122,7 +122,7 @@ Clipperz_normalizedNewLine = '\x0d\x0a';
|
|||||||
// Live Reload hoock
|
// Live Reload hoock
|
||||||
document.write('<script src="http://' + (location.host || 'localhost').split(':')[0] + ':35729/livereload.js?snipver=1"></' + 'script>')
|
document.write('<script src="http://' + (location.host || 'localhost').split(':')[0] + ':35729/livereload.js?snipver=1"></' + 'script>')
|
||||||
</script>
|
</script>
|
||||||
</div -->
|
</div>
|
||||||
|
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
@ -342,6 +342,7 @@ Clipperz.PM.DataModel.EncryptedRemoteObject.prototype = MochiKit.Base.update(nul
|
|||||||
var innerDeferredResult;
|
var innerDeferredResult;
|
||||||
|
|
||||||
if (this._objectDataStore == null) {
|
if (this._objectDataStore == null) {
|
||||||
|
//console.log("EncryptedRemoteObject._getObjectDataStore", this._reference);
|
||||||
this._objectDataStore = new Clipperz.KeyValueObjectStore(/*{'name':'EncryptedRemoteObject.objectDataStore [4]'}*/);
|
this._objectDataStore = new Clipperz.KeyValueObjectStore(/*{'name':'EncryptedRemoteObject.objectDataStore [4]'}*/);
|
||||||
|
|
||||||
innerDeferredResult = new Clipperz.Async.Deferred("EncryptedRemoteObject._getObjectDataStore <inner deferred>", {trace:false});
|
innerDeferredResult = new Clipperz.Async.Deferred("EncryptedRemoteObject._getObjectDataStore <inner deferred>", {trace:false});
|
||||||
@ -396,9 +397,10 @@ Clipperz.PM.DataModel.EncryptedRemoteObject.prototype = MochiKit.Base.update(nul
|
|||||||
var tempObj = this;
|
var tempObj = this;
|
||||||
|
|
||||||
if (this.isBrandNew()) {
|
if (this.isBrandNew()) {
|
||||||
// deferredResult = MochiKit.Async.succeed(true);
|
//console.log("EncrypedRemoteObject.hasPendingChanges - isBrandNew");
|
||||||
deferredResult = this.hasPendingChangesWhenBrandNew();
|
deferredResult = this.hasPendingChangesWhenBrandNew();
|
||||||
} else if (this.hasInitiatedObjectDataStore()) {
|
} else if (this.hasInitiatedObjectDataStore()) {
|
||||||
|
//console.log("EncrypedRemoteObject.hasPendingChanges - hasInitiatedObjectDataStore == true");
|
||||||
deferredResult = new Clipperz.Async.Deferred("EncryptedRemoteObject.hasPendingChanges", {trace:false});
|
deferredResult = new Clipperz.Async.Deferred("EncryptedRemoteObject.hasPendingChanges", {trace:false});
|
||||||
deferredResult.collectResults({
|
deferredResult.collectResults({
|
||||||
'decryptedData': [
|
'decryptedData': [
|
||||||
@ -416,6 +418,7 @@ Clipperz.PM.DataModel.EncryptedRemoteObject.prototype = MochiKit.Base.update(nul
|
|||||||
});
|
});
|
||||||
deferredResult.callback();
|
deferredResult.callback();
|
||||||
} else {
|
} else {
|
||||||
|
//console.log("EncrypedRemoteObject.hasPendingChanges - hasInitiatedObjectDataStore == false");
|
||||||
deferredResult = MochiKit.Async.succeed(false);
|
deferredResult = MochiKit.Async.succeed(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -52,6 +52,7 @@ Clipperz_normalizedNewLine = '\x0d\x0a';
|
|||||||
MochiKit.DOM.addLoadEvent(function () {
|
MochiKit.DOM.addLoadEvent(function () {
|
||||||
Clipperz.Crypto.PRNG.defaultRandomGenerator().fastEntropyAccumulationForTestingPurpose();
|
Clipperz.Crypto.PRNG.defaultRandomGenerator().fastEntropyAccumulationForTestingPurpose();
|
||||||
// MochiKit.Signal.signal(Clipperz.Signal.NotificationCenter, 'doLogin', {username:'joe', passphrase:'clipperz'});
|
// MochiKit.Signal.signal(Clipperz.Signal.NotificationCenter, 'doLogin', {username:'joe', passphrase:'clipperz'});
|
||||||
|
// MochiKit.Signal.signal(Clipperz.Signal.NotificationCenter, 'doLogin', {username:'j', passphrase:'j'});
|
||||||
});
|
});
|
||||||
/ * */
|
/ * */
|
||||||
</script>
|
</script>
|
||||||
|
@ -61,6 +61,10 @@ MochiKit.Base.update(Clipperz.Base, {
|
|||||||
return (MochiKit.Base.urlRegExp.test(aValue));
|
return (MochiKit.Base.urlRegExp.test(aValue));
|
||||||
},
|
},
|
||||||
|
|
||||||
|
// 'isBitcoin': function (aValue) {
|
||||||
|
// return (MochiKit.Base.bitcoinRegExp.test(aValue));
|
||||||
|
// },
|
||||||
|
|
||||||
'isEmail': function (aValue) {
|
'isEmail': function (aValue) {
|
||||||
return (MochiKit.Base.emailRegExp.test(aValue));
|
return (MochiKit.Base.emailRegExp.test(aValue));
|
||||||
},
|
},
|
||||||
|
@ -318,9 +318,9 @@ Clipperz.Crypto.PRNG.CryptoRandomRandomnessSource.prototype = MochiKit.Base.upda
|
|||||||
var bytesToCollect;
|
var bytesToCollect;
|
||||||
|
|
||||||
if (this.boostMode() == true) {
|
if (this.boostMode() == true) {
|
||||||
bytesToCollect = 64;
|
|
||||||
} else {
|
|
||||||
bytesToCollect = 8;
|
bytesToCollect = 8;
|
||||||
|
} else {
|
||||||
|
bytesToCollect = 32;
|
||||||
}
|
}
|
||||||
|
|
||||||
var randomValuesArray = new Uint8Array(bytesToCollect);
|
var randomValuesArray = new Uint8Array(bytesToCollect);
|
||||||
|
@ -283,6 +283,13 @@ MochiKit.Base.update(Clipperz.Date, {
|
|||||||
return new Date(Date.parse(aValue));
|
return new Date(Date.parse(aValue));
|
||||||
},
|
},
|
||||||
|
|
||||||
|
'daysBetweendDates': function (date1, date2) {
|
||||||
|
var ONE_DAY = 24 * 60 * 60 * 1000;
|
||||||
|
return Math.round(Math.abs(date1.getTime() - date2.getTime()) / ONE_DAY)
|
||||||
|
},
|
||||||
|
|
||||||
|
'distantFuture': 'Mon, 01 January 4001 00:00:00 UTC',
|
||||||
|
'distantPast': 'Tue, 04 January 0001 00:00:00 UTC',
|
||||||
//=========================================================================
|
//=========================================================================
|
||||||
|
|
||||||
'exception': {
|
'exception': {
|
||||||
|
@ -105,9 +105,11 @@ Clipperz.Base.extend(Clipperz.PM.DataModel.Record.Version.Field, Object, {
|
|||||||
if (someValues['isHidden']) {
|
if (someValues['isHidden']) {
|
||||||
result = 'PASSWORD';
|
result = 'PASSWORD';
|
||||||
} else if (Clipperz.Base.isUrl(someValues['value'])) {
|
} else if (Clipperz.Base.isUrl(someValues['value'])) {
|
||||||
result = 'URL'
|
result = 'URL';
|
||||||
|
// } else if (Clipperz.Base.isBitcoin(someValues['value'])) {
|
||||||
|
// result = 'BITCOIN';
|
||||||
} else if (Clipperz.Base.isEmail(someValues['value'])) {
|
} else if (Clipperz.Base.isEmail(someValues['value'])) {
|
||||||
result = 'EMAIL'
|
result = 'EMAIL';
|
||||||
};
|
};
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
|
94
frontend/gamma/js/Clipperz/PM/DataModel/User.AccountInfo.js
Normal file
94
frontend/gamma/js/Clipperz/PM/DataModel/User.AccountInfo.js
Normal file
@ -0,0 +1,94 @@
|
|||||||
|
/*
|
||||||
|
|
||||||
|
Copyright 2008-2013 Clipperz Srl
|
||||||
|
|
||||||
|
This file is part of Clipperz, the online password manager.
|
||||||
|
For further information about its features and functionalities please
|
||||||
|
refer to http://www.clipperz.com.
|
||||||
|
|
||||||
|
* Clipperz 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.
|
||||||
|
|
||||||
|
* Clipperz 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 Clipperz. If not, see http://www.gnu.org/licenses/.
|
||||||
|
|
||||||
|
*/
|
||||||
|
|
||||||
|
Clipperz.PM.DataModel.User.AccountInfo = function(args) {
|
||||||
|
Clipperz.PM.DataModel.User.AccountInfo.superclass.constructor.apply(this, arguments);
|
||||||
|
console.log("new AccountInfo", args);
|
||||||
|
|
||||||
|
// {
|
||||||
|
// "expirationDate": "Sat, 18 January 2014 11:56:17 UTC",
|
||||||
|
// "featureSet": "EXPIRED",
|
||||||
|
// "features": [
|
||||||
|
// "OFFLINE_COPY",
|
||||||
|
// "LIST_CARDS"
|
||||||
|
// ],
|
||||||
|
// "isExpired": true,
|
||||||
|
// "isExpiring": false,
|
||||||
|
// "latestActiveLevel": "TRIAL",
|
||||||
|
// "latestActiveThreshold": 0.0,
|
||||||
|
// "paymentVerificationPending": false,
|
||||||
|
// "payments": [],
|
||||||
|
// "referenceDate": "Mon, 03 March 2014 09:54:50 UTC"
|
||||||
|
// }
|
||||||
|
|
||||||
|
this._args = args;
|
||||||
|
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
Clipperz.Base.extend(Clipperz.PM.DataModel.User.AccountInfo, Object, {
|
||||||
|
|
||||||
|
'toString': function() {
|
||||||
|
return "Clipperz.PM.DataModel.User.AccountInfo";
|
||||||
|
},
|
||||||
|
|
||||||
|
'args': function () {
|
||||||
|
return this._args;
|
||||||
|
},
|
||||||
|
|
||||||
|
'expirationDate': function () {
|
||||||
|
return Clipperz.PM.Date.parse(this.args()['expirationDate']);
|
||||||
|
},
|
||||||
|
|
||||||
|
'latestActiveLevel': function () {
|
||||||
|
return this.args()['latestActiveLevel'];
|
||||||
|
},
|
||||||
|
|
||||||
|
'latestActiveThreshold': function () {
|
||||||
|
return this.args()['latestActiveThreshold'];
|
||||||
|
},
|
||||||
|
|
||||||
|
'status': function () {
|
||||||
|
return this.args()['featureSet'];
|
||||||
|
},
|
||||||
|
|
||||||
|
'isExpiring': function () {
|
||||||
|
return this.args()['isExpiring'];
|
||||||
|
},
|
||||||
|
|
||||||
|
'isExpired': function () {
|
||||||
|
return this.args()['isExpired'];
|
||||||
|
},
|
||||||
|
|
||||||
|
'paymentVerificationPending': function () {
|
||||||
|
return this.args()['paymentVerificationPending'];
|
||||||
|
},
|
||||||
|
|
||||||
|
//=========================================================================
|
||||||
|
__syntaxFix__: "syntax fix"
|
||||||
|
});
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
|
@ -327,7 +327,7 @@ Clipperz.Base.extend(Clipperz.PM.DataModel.User, Object, {
|
|||||||
var oneTimePasswords;
|
var oneTimePasswords;
|
||||||
|
|
||||||
// this.setServerLockValue(someServerData['lock']);
|
// this.setServerLockValue(someServerData['lock']);
|
||||||
|
console.log("USER.unpackServerData", someServerData);
|
||||||
headerVersion = this.headerFormatVersion(someServerData['header']);
|
headerVersion = this.headerFormatVersion(someServerData['header']);
|
||||||
|
|
||||||
switch (headerVersion) {
|
switch (headerVersion) {
|
||||||
@ -410,7 +410,9 @@ Clipperz.Base.extend(Clipperz.PM.DataModel.User, Object, {
|
|||||||
'recordsIndex': recordsIndex,
|
'recordsIndex': recordsIndex,
|
||||||
'preferences': preferences,
|
'preferences': preferences,
|
||||||
'oneTimePasswords': oneTimePasswords
|
'oneTimePasswords': oneTimePasswords
|
||||||
}
|
},
|
||||||
|
// 'accountInfo': new Clipperz.PM.DataModel.User.AccountInfo(someServerData['accountInfo']),
|
||||||
|
'offlineCopyNeeded': someServerData['offlineCopyNeeded']
|
||||||
};
|
};
|
||||||
|
|
||||||
this._serverData = unpackedData;
|
this._serverData = unpackedData;
|
||||||
@ -449,6 +451,11 @@ Clipperz.Base.extend(Clipperz.PM.DataModel.User, Object, {
|
|||||||
return deferredResult;
|
return deferredResult;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
'resetAllData': function () {
|
||||||
|
this.deleteAllCleanTextData();
|
||||||
|
this._serverData = null;
|
||||||
|
},
|
||||||
|
|
||||||
//-------------------------------------------------------------------------
|
//-------------------------------------------------------------------------
|
||||||
|
|
||||||
'connectionVersion': function() {
|
'connectionVersion': function() {
|
||||||
@ -492,6 +499,13 @@ Clipperz.Base.extend(Clipperz.PM.DataModel.User, Object, {
|
|||||||
], {trace:false})
|
], {trace:false})
|
||||||
},
|
},
|
||||||
|
|
||||||
|
'getCurrentAccountInfo': function () {
|
||||||
|
return Clipperz.Async.callbacks("User.getHeaderIndex", [
|
||||||
|
MochiKit.Base.method(this, 'getServerData'),
|
||||||
|
MochiKit.Base.itemgetter('accountInfo')
|
||||||
|
], {trace:false})
|
||||||
|
},
|
||||||
|
|
||||||
//=========================================================================
|
//=========================================================================
|
||||||
|
|
||||||
'getRecords': function () {
|
'getRecords': function () {
|
||||||
@ -779,6 +793,20 @@ Clipperz.Base.extend(Clipperz.PM.DataModel.User, Object, {
|
|||||||
return deferredResult;
|
return deferredResult;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
'deleteAccount': function() {
|
||||||
|
var deferredResult;
|
||||||
|
|
||||||
|
//MochiKit.Logging.logDebug(">>> user.deleteAccountAction - " + this);
|
||||||
|
this.deleteAllCleanTextData();
|
||||||
|
deferredResult = new Clipperz.Async.Deferred("User.deleteAccount", {trace:false});
|
||||||
|
deferredResult.addCallback(MochiKit.Base.method(this.connection(), 'message'), 'deleteUser');
|
||||||
|
// deferredResult.addCallback(MochiKit.Base.method(this, 'resetAllLocalData'));
|
||||||
|
deferredResult.callback();
|
||||||
|
//MochiKit.Logging.logDebug("<<< user.deleteAccountAction - " + this);
|
||||||
|
|
||||||
|
return deferredResult;
|
||||||
|
},
|
||||||
|
|
||||||
//=========================================================================
|
//=========================================================================
|
||||||
__syntaxFix__: "syntax fix"
|
__syntaxFix__: "syntax fix"
|
||||||
});
|
});
|
||||||
|
@ -350,7 +350,7 @@ MochiKit.Base.update(Clipperz.PM.UI.Mobile.Controllers.MainController.prototype,
|
|||||||
'selectCardHandler': function (aCardReference) {
|
'selectCardHandler': function (aCardReference) {
|
||||||
var deferredResult;
|
var deferredResult;
|
||||||
|
|
||||||
deferredResult = new Clipperz.Async.Deferred("MainController.selectCardHandler", {trace:true});
|
deferredResult = new Clipperz.Async.Deferred("MainController.selectCardHandler", {trace:false});
|
||||||
deferredResult.addMethod(this.cardDetail(), 'render');
|
deferredResult.addMethod(this.cardDetail(), 'render');
|
||||||
deferredResult.addMethod(this.user(), 'getRecord', aCardReference);
|
deferredResult.addMethod(this.user(), 'getRecord', aCardReference);
|
||||||
deferredResult.addMethod(this.cardDetail(), 'showCard');
|
deferredResult.addMethod(this.cardDetail(), 'showCard');
|
||||||
|
@ -26,6 +26,8 @@ Clipperz.Base.module('Clipperz.PM.UI.Web.Components');
|
|||||||
Clipperz.PM.UI.Web.Components.AccountPanel = function(args) {
|
Clipperz.PM.UI.Web.Components.AccountPanel = function(args) {
|
||||||
args = args || {};
|
args = args || {};
|
||||||
|
|
||||||
|
this._credentialVefificationFunction = args['credentialVefificationFunction'];
|
||||||
|
|
||||||
Clipperz.PM.UI.Web.Components.AccountPanel.superclass.constructor.apply(this, arguments);
|
Clipperz.PM.UI.Web.Components.AccountPanel.superclass.constructor.apply(this, arguments);
|
||||||
|
|
||||||
// this._initiallySelectedTab = args.selected || 'ACCOUNT';
|
// this._initiallySelectedTab = args.selected || 'ACCOUNT';
|
||||||
@ -50,6 +52,10 @@ Clipperz.PM.UI.Web.Components.AccountPanel = function(args) {
|
|||||||
'LOGIN_HISTORY': {
|
'LOGIN_HISTORY': {
|
||||||
tab: 'loginHistoryTab',
|
tab: 'loginHistoryTab',
|
||||||
panel: 'loginHistoryPanel'
|
panel: 'loginHistoryPanel'
|
||||||
|
},
|
||||||
|
'DELETE_ACCOUNT': {
|
||||||
|
tab: 'deleteAccountTab',
|
||||||
|
panel: 'deleteAccountPanel'
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -78,7 +84,8 @@ Clipperz.Base.extend(Clipperz.PM.UI.Web.Components.AccountPanel, Clipperz.PM.UI.
|
|||||||
{tag:'li', id:this.getId('passphraseTab'), children:[{tag:'a', href:'#', html:'Passphrase'}], cls:'first'},
|
{tag:'li', id:this.getId('passphraseTab'), children:[{tag:'a', href:'#', html:'Passphrase'}], cls:'first'},
|
||||||
{tag:'li', id:this.getId('OTPTab'), children:[{tag:'a', href:'#', html:'One Time Passwords'}]},
|
{tag:'li', id:this.getId('OTPTab'), children:[{tag:'a', href:'#', html:'One Time Passwords'}]},
|
||||||
{tag:'li', id:this.getId('preferencesTab'), children:[{tag:'a', href:'#', html:'Preferences'}]},
|
{tag:'li', id:this.getId('preferencesTab'), children:[{tag:'a', href:'#', html:'Preferences'}]},
|
||||||
{tag:'li', id:this.getId('loginHistoryTab'), children:[{tag:'a', href:'#', html:'Login history'}]}
|
{tag:'li', id:this.getId('loginHistoryTab'), children:[{tag:'a', href:'#', html:'Login history'}]},
|
||||||
|
{tag:'li', id:this.getId('deleteAccountTab'), children:[{tag:'a', href:'#', html:'Delete account'}]}
|
||||||
]}
|
]}
|
||||||
]}
|
]}
|
||||||
]},
|
]},
|
||||||
@ -130,6 +137,30 @@ Clipperz.Base.extend(Clipperz.PM.UI.Web.Components.AccountPanel, Clipperz.PM.UI.
|
|||||||
]},
|
]},
|
||||||
{tag:'li', id:this.getId('loginHistoryPanel'), children:[
|
{tag:'li', id:this.getId('loginHistoryPanel'), children:[
|
||||||
// {tag:'h3', html:"-- Login History --"}
|
// {tag:'h3', html:"-- Login History --"}
|
||||||
|
]},
|
||||||
|
{tag:'li', id:this.getId('deleteAccountPanel'), children:[
|
||||||
|
{tag:'h3', cls:'deleteAccount', html:"Delete your account"},
|
||||||
|
{tag:'form', id:this.getId('deleteAccountForm'), cls:'deleteAccount', children:[
|
||||||
|
{tag:'div', cls:'currentCredentials', children:[
|
||||||
|
{tag:'div', cls:'field username', children:[
|
||||||
|
{tag:'label', html:"username", 'for':this.getId('deleteAccount_currentUsername')},
|
||||||
|
{tag:'input', id:this.getId('deleteAccount_currentUsername')}
|
||||||
|
]},
|
||||||
|
{tag:'div', cls:'field passphrase', children:[
|
||||||
|
{tag:'label', html:"passphrase", 'for':this.getId('deleteAccount_currentPassphrase')},
|
||||||
|
{tag:'input', type:'password', id:this.getId('deleteAccount_currentPassphrase')}
|
||||||
|
]},
|
||||||
|
{tag:'div', cls:'confirm', children:[
|
||||||
|
{tag:'input', type:'checkbox', id:this.getId('deleteAccount_checkbox')},
|
||||||
|
{tag:'label', html:"I understand that all my data will be deleted and that this action is irreversible", 'for':this.getId('deleteAccount_checkbox')}
|
||||||
|
]}
|
||||||
|
]}
|
||||||
|
]},
|
||||||
|
{tag:'div', cls:'clear'},
|
||||||
|
{tag:'div', cls:'confirmButton', id:this.getId('confirmationButton'), children:[
|
||||||
|
{tag:'a', id:this.getId('deleteAccountButton'), href:'#', html:"Delete my account", cls:'deleteAccountButton disabled'}
|
||||||
|
]}
|
||||||
|
|
||||||
]}
|
]}
|
||||||
]}
|
]}
|
||||||
]}
|
]}
|
||||||
@ -139,6 +170,54 @@ Clipperz.Base.extend(Clipperz.PM.UI.Web.Components.AccountPanel, Clipperz.PM.UI.
|
|||||||
]);
|
]);
|
||||||
|
|
||||||
this.tabPanelController().setup({selected:this.initiallySelectedTab()});
|
this.tabPanelController().setup({selected:this.initiallySelectedTab()});
|
||||||
|
MochiKit.Signal.connect(this.getId('deleteAccountButton'), 'onclick', this, 'deleteAccount');
|
||||||
|
|
||||||
|
MochiKit.Signal.connect(this.getId('deleteAccount_currentUsername'), 'onchange', this, 'deleteAccountFormChangedValue');
|
||||||
|
MochiKit.Signal.connect(this.getId('deleteAccount_currentUsername'), 'onkeyup', this, 'deleteAccountFormChangedValue');
|
||||||
|
MochiKit.Signal.connect(this.getId('deleteAccount_currentPassphrase'), 'onchange', this, 'deleteAccountFormChangedValue');
|
||||||
|
MochiKit.Signal.connect(this.getId('deleteAccount_currentPassphrase'), 'onkeyup', this, 'deleteAccountFormChangedValue');
|
||||||
|
MochiKit.Signal.connect(this.getId('deleteAccount_checkbox'), 'onchange', this, 'deleteAccountFormChangedValue');
|
||||||
|
},
|
||||||
|
|
||||||
|
//-------------------------------------------------------------------------
|
||||||
|
|
||||||
|
'deleteAccount': function (anEvent) {
|
||||||
|
console.log("DELETE ACCOUNT");
|
||||||
|
|
||||||
|
anEvent.preventDefault();
|
||||||
|
MochiKit.Signal.signal(Clipperz.Signal.NotificationCenter, 'deleteAccount', this.deleteAccountCredentials());
|
||||||
|
},
|
||||||
|
|
||||||
|
'deleteAccountCredentials': function () {
|
||||||
|
return {
|
||||||
|
username: this.getElement('deleteAccount_currentUsername').value,
|
||||||
|
passphrase: this.getElement('deleteAccount_currentPassphrase').value
|
||||||
|
};
|
||||||
|
},
|
||||||
|
|
||||||
|
'deleteAccountFormChangedValue': function (anEvent) {
|
||||||
|
anEvent.preventDefault();
|
||||||
|
|
||||||
|
if (this.verifyDeleteAccountCredentials()) {
|
||||||
|
MochiKit.DOM.removeElementClass(this.getElement('deleteAccountButton'), 'disabled');
|
||||||
|
} else {
|
||||||
|
MochiKit.DOM.addElementClass(this.getElement('deleteAccountButton'), 'disabled')
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
'verifyDeleteAccountCredentials': function () {
|
||||||
|
var result;
|
||||||
|
var credentials;
|
||||||
|
var checkboxChecked;
|
||||||
|
|
||||||
|
result = false;
|
||||||
|
checkboxChecked = this.getElement('deleteAccount_checkbox').checked;
|
||||||
|
|
||||||
|
if (checkboxChecked) {
|
||||||
|
result = this._credentialVefificationFunction(this.deleteAccountCredentials());
|
||||||
|
}
|
||||||
|
|
||||||
|
return result;
|
||||||
},
|
},
|
||||||
|
|
||||||
//-------------------------------------------------------------------------
|
//-------------------------------------------------------------------------
|
||||||
|
@ -132,6 +132,10 @@ Clipperz.Base.extend(Clipperz.PM.UI.Web.Components.CardDialogRecordFieldComponen
|
|||||||
MochiKit.Style.showElement(this.getId('actionLink'));
|
MochiKit.Style.showElement(this.getId('actionLink'));
|
||||||
MochiKit.DOM.setElementClass(this.getId('actionLink'), 'url');
|
MochiKit.DOM.setElementClass(this.getId('actionLink'), 'url');
|
||||||
break;
|
break;
|
||||||
|
case 'BITCOIN':
|
||||||
|
MochiKit.Style.showElement(this.getId('actionLink'));
|
||||||
|
MochiKit.DOM.setElementClass(this.getId('actionLink'), 'url');
|
||||||
|
break;
|
||||||
case 'EMAIL':
|
case 'EMAIL':
|
||||||
MochiKit.Style.showElement(this.getId('actionLink'));
|
MochiKit.Style.showElement(this.getId('actionLink'));
|
||||||
MochiKit.DOM.setElementClass(this.getId('actionLink'), 'email');
|
MochiKit.DOM.setElementClass(this.getId('actionLink'), 'email');
|
||||||
|
@ -144,24 +144,16 @@ Clipperz.Base.extend(Clipperz.PM.UI.Web.Components.LoginForm, Clipperz.PM.UI.Com
|
|||||||
//-------------------------------------------------------------------------
|
//-------------------------------------------------------------------------
|
||||||
|
|
||||||
'loginEventHandler': function(anEvent) {
|
'loginEventHandler': function(anEvent) {
|
||||||
// var username;
|
var credentials;
|
||||||
// var passphrase;
|
|
||||||
var signalArguments;
|
|
||||||
|
|
||||||
anEvent.preventDefault();
|
anEvent.preventDefault();
|
||||||
|
|
||||||
// username = this.getElement('usernameField').value;
|
credentials = {
|
||||||
// passphrase = this.getElement('passphraseField').value;
|
|
||||||
|
|
||||||
// signalArguments = {username:username};
|
|
||||||
// signalArguments.passphrase = passphrase;
|
|
||||||
|
|
||||||
signalArguments = {
|
|
||||||
'username': this.getElement('usernameField').value,
|
'username': this.getElement('usernameField').value,
|
||||||
'passphrase': this.getElement('passphraseField').value
|
'passphrase': this.getElement('passphraseField').value
|
||||||
};
|
};
|
||||||
|
|
||||||
MochiKit.Signal.signal(this, 'doLogin', signalArguments);
|
MochiKit.Signal.signal(this, 'doLogin', credentials);
|
||||||
},
|
},
|
||||||
|
|
||||||
//-------------------------------------------------------------------------
|
//-------------------------------------------------------------------------
|
||||||
|
@ -0,0 +1,220 @@
|
|||||||
|
/*
|
||||||
|
|
||||||
|
Copyright 2008-2013 Clipperz Srl
|
||||||
|
|
||||||
|
This file is part of Clipperz, the online password manager.
|
||||||
|
For further information about its features and functionalities please
|
||||||
|
refer to http://www.clipperz.com.
|
||||||
|
|
||||||
|
* Clipperz 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.
|
||||||
|
|
||||||
|
* Clipperz 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 Clipperz. If not, see http://www.gnu.org/licenses/.
|
||||||
|
|
||||||
|
*/
|
||||||
|
|
||||||
|
Clipperz.Base.module('Clipperz.PM.UI.Web.Components');
|
||||||
|
|
||||||
|
Clipperz.PM.UI.Web.Components.PaymentComponent = function(args) {
|
||||||
|
args = args || {};
|
||||||
|
|
||||||
|
Clipperz.PM.UI.Web.Components.PaymentComponent.superclass.constructor.apply(this, arguments);
|
||||||
|
|
||||||
|
this._subscriptionOptions = null;
|
||||||
|
this._currencies = null;
|
||||||
|
this._selectedCurrency = 'mBTC';
|
||||||
|
this._selectedOption = 'FAN';
|
||||||
|
|
||||||
|
// this._displayMode = 'fixed'; // 'scrollable';
|
||||||
|
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
//=============================================================================
|
||||||
|
|
||||||
|
Clipperz.Base.extend(Clipperz.PM.UI.Web.Components.PaymentComponent, Clipperz.PM.UI.Common.Components.BaseComponent, {
|
||||||
|
|
||||||
|
//-------------------------------------------------------------------------
|
||||||
|
|
||||||
|
'toString': function () {
|
||||||
|
return "Clipperz.PM.UI.Web.Components.PaymentComponent component";
|
||||||
|
},
|
||||||
|
|
||||||
|
//-------------------------------------------------------------------------
|
||||||
|
|
||||||
|
'subscriptionOptions': function () {
|
||||||
|
return this._subscriptionOptions;
|
||||||
|
},
|
||||||
|
|
||||||
|
'setSubscriptionOptions': function (someSubscriptionOptions) {
|
||||||
|
this._subscriptionOptions = someSubscriptionOptions['options'];
|
||||||
|
this._currencies = MochiKit.Base.keys(MochiKit.Base.values(MochiKit.Base.values(someSubscriptionOptions['options'])[0])[0]['value']);
|
||||||
|
if (typeof(someSubscriptionOptions['latestActiveLevel']) != 'undefined') {
|
||||||
|
this._selectedOption = someSubscriptionOptions['latestActiveLevel'];
|
||||||
|
}
|
||||||
|
|
||||||
|
this.renderSubscriptionOptions(this._subscriptionOptions);
|
||||||
|
},
|
||||||
|
|
||||||
|
//............................................................................
|
||||||
|
|
||||||
|
'currencies': function () {
|
||||||
|
return this._currencies;
|
||||||
|
},
|
||||||
|
|
||||||
|
'selectedCurrency': function () {
|
||||||
|
return this._selectedCurrency;
|
||||||
|
},
|
||||||
|
|
||||||
|
'setSelectedCurrency': function (aValue) {
|
||||||
|
this._selectedCurrency = aValue;
|
||||||
|
},
|
||||||
|
|
||||||
|
'setSelectedCurrencyIfNull': function (aValue) {
|
||||||
|
if (this._selectedCurrency == null) {
|
||||||
|
this._selectedCurrency = aValue;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
//............................................................................
|
||||||
|
|
||||||
|
'selectedOption': function () {
|
||||||
|
return this._selectedOption;
|
||||||
|
},
|
||||||
|
|
||||||
|
'setSelectedOption': function (aValue) {
|
||||||
|
this._selectedOption = aValue;
|
||||||
|
},
|
||||||
|
|
||||||
|
//-------------------------------------------------------------------------
|
||||||
|
|
||||||
|
'renderSelf': function () {
|
||||||
|
this.append(this.element(), {tag:'div', cls:'PaymentDialog loading', id:this.getId('panel'), children: [
|
||||||
|
{tag:'div', id:this.getId('subscriptions'), cls:'subscriptions'},
|
||||||
|
{tag:'div', cls:'footer', children:[
|
||||||
|
{tag:'div', id:this.getId('cancelButton'), cls:'button cancel', html:"cancel"},
|
||||||
|
{tag:'div', id:this.getId('payButton'), cls:'button pay', html:"pay"}
|
||||||
|
]}
|
||||||
|
]});
|
||||||
|
|
||||||
|
MochiKit.Signal.connect(this.getElement('cancelButton'), 'onclick', this, 'handleCancel');
|
||||||
|
MochiKit.Signal.connect(this.getElement('payButton'), 'onclick', this, 'handlePayButtonClick');
|
||||||
|
},
|
||||||
|
|
||||||
|
//-------------------------------------------------------------------------
|
||||||
|
|
||||||
|
'priceOptionComponent': function (aCurrency, aSelectedOption, aSubscriptionInfo) {
|
||||||
|
var isSelected = (aSubscriptionInfo['code'] == aSelectedOption);
|
||||||
|
|
||||||
|
return {tag:'li', 'data-type':'option', 'data-code':aSubscriptionInfo['code'], cls:isSelected ? 'selected' : '', children:[
|
||||||
|
{tag:'h3', html:aSubscriptionInfo['name']},
|
||||||
|
{tag:'h5', cls:'currency', html:aCurrency},
|
||||||
|
{tag:'h5', cls:'value', html:aSubscriptionInfo['value'][aCurrency]}
|
||||||
|
]};
|
||||||
|
},
|
||||||
|
|
||||||
|
'optionComparator': function (aOption, bOption) {
|
||||||
|
return MochiKit.Base.compare(aOption['CLZ'], bOption['CLZ']);
|
||||||
|
},
|
||||||
|
|
||||||
|
'renderCurrency': function (aSelectedCurrency, aCurrency) {
|
||||||
|
return {tag:'li', 'data-type':'currency', 'data-code':aCurrency, cls:aCurrency == aSelectedCurrency ? 'selected' : '', html:aCurrency}
|
||||||
|
},
|
||||||
|
|
||||||
|
'allSubscriptionOptions': function () {
|
||||||
|
return MochiKit.Selector.findChildElements(this.getElement('subscriptions'), ["div.options li"]);
|
||||||
|
},
|
||||||
|
|
||||||
|
'allCurrencyOptions': function () {
|
||||||
|
return MochiKit.Selector.findChildElements(this.getElement('subscriptions'), ["ul.currencies li"]);
|
||||||
|
},
|
||||||
|
|
||||||
|
'renderSubscriptionOptions': function (someSubscriptionOptions, overwrite) {
|
||||||
|
var currentCurrency = this.selectedCurrency();
|
||||||
|
var currencyRenderer = MochiKit.Base.partial(this.renderCurrency, this.selectedCurrency())
|
||||||
|
var subscriptionOptionRenderer = MochiKit.Base.partial(this.priceOptionComponent, this.selectedCurrency(), this.selectedOption());
|
||||||
|
var self = this;
|
||||||
|
|
||||||
|
if (overwrite) {
|
||||||
|
MochiKit.Base.map(MochiKit.Signal.disconnectAll, this.allCurrencyOptions());
|
||||||
|
MochiKit.Base.map(MochiKit.Signal.disconnectAll, this.allSubscriptionOptions());
|
||||||
|
this.getElement('subscriptions').innerHTML = '';
|
||||||
|
}
|
||||||
|
|
||||||
|
this.append(this.getElement('subscriptions'), {tag:'ul', cls:'currencies', children:MochiKit.Base.map(currencyRenderer, this.currencies())});
|
||||||
|
|
||||||
|
this.append(this.getElement('subscriptions'), {tag:'div', cls:'options', children:[
|
||||||
|
{tag:'div', cls:'yearly', children:[
|
||||||
|
{tag:'h1', html:"Yearly"},
|
||||||
|
{tag:'ul', children:MochiKit.Base.map(subscriptionOptionRenderer, MochiKit.Base.values(someSubscriptionOptions['P1Y']).sort(this.optionComparator))}
|
||||||
|
]},
|
||||||
|
{tag:'div', cls:'perpetual', children:[
|
||||||
|
{tag:'h1', html:"Perpetual"},
|
||||||
|
{tag:'ul', children:MochiKit.Base.map(subscriptionOptionRenderer, MochiKit.Base.values(someSubscriptionOptions['--']).sort(this.optionComparator))}
|
||||||
|
]}
|
||||||
|
]});
|
||||||
|
|
||||||
|
MochiKit.Base.map(function (aLi) { MochiKit.Signal.connect(aLi, 'onclick', self, 'handleChangeCurrencySelection') }, this.allCurrencyOptions());
|
||||||
|
MochiKit.Base.map(function (aLi) { MochiKit.Signal.connect(aLi, 'onclick', self, 'handleChangeOptionSelection') }, this.allSubscriptionOptions());
|
||||||
|
},
|
||||||
|
|
||||||
|
//-------------------------------------------------------------------------
|
||||||
|
|
||||||
|
'handleChangeOptionSelection': function (anEvent) {
|
||||||
|
var code = MochiKit.DOM.getNodeAttribute(anEvent.src(), 'data-code');
|
||||||
|
|
||||||
|
if (code != this.selectedOption()) {
|
||||||
|
MochiKit.Base.map(function (aLi) { MochiKit.DOM.removeElementClass(aLi, 'selected') }, this.allSubscriptionOptions());
|
||||||
|
MochiKit.DOM.addElementClass(anEvent.src(), 'selected');
|
||||||
|
this.setSelectedOption(code);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
'handleChangeCurrencySelection': function (anEvent) {
|
||||||
|
var code = MochiKit.DOM.getNodeAttribute(anEvent.src(), 'data-code');
|
||||||
|
|
||||||
|
if (code != this.selectedCurrency()) {
|
||||||
|
MochiKit.Base.map(function (aLi) { MochiKit.DOM.removeElementClass(aLi, 'selected') }, this.allCurrencyOptions());
|
||||||
|
MochiKit.DOM.addElementClass(anEvent.src(), 'selected');
|
||||||
|
this.setSelectedCurrency(code);
|
||||||
|
this.renderSubscriptionOptions(this.subscriptionOptions(), true);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
'handlePayButtonClick': function (anEvent) {
|
||||||
|
console.log("PAY: ", this.selectedOption(), this.selectedCurrency());
|
||||||
|
MochiKit.Signal.signal(this, 'pay', {currency:this.selectedCurrency(), type:this.selectedOption()});
|
||||||
|
},
|
||||||
|
|
||||||
|
'handleCancel': function (anEvent) {
|
||||||
|
console.log("CANCEL");
|
||||||
|
MochiKit.Signal.signal(this, 'cancel');
|
||||||
|
},
|
||||||
|
|
||||||
|
/*
|
||||||
|
'displayMode': function () {
|
||||||
|
return this._displayMode;
|
||||||
|
},
|
||||||
|
|
||||||
|
'setDisplayMode': function (aValue) {
|
||||||
|
this._displayMode = aValue;
|
||||||
|
},
|
||||||
|
*/
|
||||||
|
|
||||||
|
//=========================================================================
|
||||||
|
|
||||||
|
'showQrCode': function (someParameters) {
|
||||||
|
console.log("SHOW QR CODE", someParameters);
|
||||||
|
},
|
||||||
|
|
||||||
|
//=========================================================================
|
||||||
|
__syntaxFix__: "syntax fix"
|
||||||
|
});
|
@ -110,7 +110,6 @@ Clipperz.Base.extend(Clipperz.PM.UI.Web.Components.UserInfoBox, Clipperz.PM.UI.C
|
|||||||
|
|
||||||
deferredResult = Clipperz.Async.callbacks("UserInfoBox.unlock", [
|
deferredResult = Clipperz.Async.callbacks("UserInfoBox.unlock", [
|
||||||
MochiKit.Base.partial(Clipperz.Visual.deferredAnimation, MochiKit.Visual.fade, maskElement, {from:0.75, to:0.0, duration:0.5}),
|
MochiKit.Base.partial(Clipperz.Visual.deferredAnimation, MochiKit.Visual.fade, maskElement, {from:0.75, to:0.0, duration:0.5}),
|
||||||
// Clipperz.Visual.deferredAnimation(MochiKit.Visual.fade, maskElement, {from:0.75, to:0.0, duration:0.5}),
|
|
||||||
MochiKit.Base.partial(MochiKit.DOM.removeElementClass, this.element(), 'locked')
|
MochiKit.Base.partial(MochiKit.DOM.removeElementClass, this.element(), 'locked')
|
||||||
], {trace:false});
|
], {trace:false});
|
||||||
},
|
},
|
||||||
@ -119,16 +118,7 @@ Clipperz.Base.extend(Clipperz.PM.UI.Web.Components.UserInfoBox, Clipperz.PM.UI.C
|
|||||||
|
|
||||||
'askForPassphrase': function () {
|
'askForPassphrase': function () {
|
||||||
var unlockPasswordComponent;
|
var unlockPasswordComponent;
|
||||||
/*
|
|
||||||
var deferredResult;
|
|
||||||
|
|
||||||
deferredResult = new Clipperz.Async.Deferred("UserInfoBox.askForPassphrase", {trace:false});
|
|
||||||
deferredResult.addCallback(MochiKit.Async.succeed, 'test');
|
|
||||||
|
|
||||||
deferredResult.callback();
|
|
||||||
|
|
||||||
return deferredResult;
|
|
||||||
*/
|
|
||||||
unlockPasswordComponent = new Clipperz.PM.UI.Web.Components.UnlockPasswordComponent({
|
unlockPasswordComponent = new Clipperz.PM.UI.Web.Components.UnlockPasswordComponent({
|
||||||
'title': "Unlock account",
|
'title': "Unlock account",
|
||||||
'text': "Insert the passprase to unlock the account",
|
'text': "Insert the passprase to unlock the account",
|
||||||
@ -166,9 +156,12 @@ Clipperz.Base.extend(Clipperz.PM.UI.Web.Components.UserInfoBox, Clipperz.PM.UI.C
|
|||||||
{tag:'span', id:this.getId('directLoginsLabel'), html:"direct logins"}
|
{tag:'span', id:this.getId('directLoginsLabel'), html:"direct logins"}
|
||||||
]}
|
]}
|
||||||
]},
|
]},
|
||||||
|
// {tag:'div', cls:'accountInfo', id:this.getId('accountInfo'), children:[
|
||||||
|
// {tag:'h5', html:"Account info"},
|
||||||
|
// ]},
|
||||||
{tag:'div', cls:'accountInfo', children:[
|
{tag:'div', cls:'accountInfo', children:[
|
||||||
{tag:'div', cls:'payButton', children:[
|
{tag:'div', cls:'payButton', children:[
|
||||||
{tag:'a', href:'#', id:this.getId('payButton'), cls:'info', html:"info"}
|
{tag:'a', href:'#', id:this.getId('infoButton'), cls:'info', html:"info"}
|
||||||
]},
|
]},
|
||||||
{tag:'h5', html:"Account info"},
|
{tag:'h5', html:"Account info"},
|
||||||
{tag:'div', cls:'accountStatus', children:[
|
{tag:'div', cls:'accountStatus', children:[
|
||||||
@ -177,12 +170,10 @@ Clipperz.Base.extend(Clipperz.PM.UI.Web.Components.UserInfoBox, Clipperz.PM.UI.C
|
|||||||
]},
|
]},
|
||||||
{tag:'div', cls:'accountLevel', children:[
|
{tag:'div', cls:'accountLevel', children:[
|
||||||
{tag:'span', cls:'label', html:"level"},
|
{tag:'span', cls:'label', html:"level"},
|
||||||
// {tag:'span', cls:'level', html:"★☆☆☆"}
|
|
||||||
{tag:'span', cls:'level', html:"☆☆☆☆"}
|
{tag:'span', cls:'level', html:"☆☆☆☆"}
|
||||||
]},
|
]},
|
||||||
{tag:'div', cls:'accountExpiration', children:[
|
{tag:'div', cls:'accountExpiration', children:[
|
||||||
{tag:'span', cls:'label', html:"expires"},
|
{tag:'span', cls:'label', html:"expires"},
|
||||||
// {tag:'span', cls:'expriation', html:"on 26 April 2014"}
|
|
||||||
{tag:'span', cls:'expriation', html:"never"}
|
{tag:'span', cls:'expriation', html:"never"}
|
||||||
]}
|
]}
|
||||||
]},
|
]},
|
||||||
@ -193,7 +184,7 @@ Clipperz.Base.extend(Clipperz.PM.UI.Web.Components.UserInfoBox, Clipperz.PM.UI.C
|
|||||||
|
|
||||||
MochiKit.Signal.connect(this.getElement('logout'), 'onclick', this, 'handleLogout');
|
MochiKit.Signal.connect(this.getElement('logout'), 'onclick', this, 'handleLogout');
|
||||||
MochiKit.Signal.connect(this.getElement('lock'), 'onclick', this, 'toggleLock');
|
MochiKit.Signal.connect(this.getElement('lock'), 'onclick', this, 'toggleLock');
|
||||||
MochiKit.Signal.connect(this.getElement('payButton'), 'onclick', this, 'handlePayButton');
|
MochiKit.Signal.connect(this.getElement('infoButton'), 'onclick', this, 'handleInfoButton');
|
||||||
|
|
||||||
this._lockTooltip = new Clipperz.PM.UI.Common.Components.Tooltip({
|
this._lockTooltip = new Clipperz.PM.UI.Common.Components.Tooltip({
|
||||||
element: this.getElement('lock'),
|
element: this.getElement('lock'),
|
||||||
@ -207,149 +198,21 @@ Clipperz.Base.extend(Clipperz.PM.UI.Web.Components.UserInfoBox, Clipperz.PM.UI.C
|
|||||||
]}
|
]}
|
||||||
);
|
);
|
||||||
MochiKit.Style.hideElement(this.getId('modalDialogMask'));
|
MochiKit.Style.hideElement(this.getId('modalDialogMask'));
|
||||||
|
|
||||||
// this.drawUserInfoBackground(this.getElement('canvas'));
|
|
||||||
},
|
},
|
||||||
|
|
||||||
//-------------------------------------------------------------------------
|
//-------------------------------------------------------------------------
|
||||||
|
|
||||||
'handlePayButton': function (anEvent) {
|
'handleInfoButton': function (anEvent) {
|
||||||
anEvent.preventDefault();
|
anEvent.preventDefault();
|
||||||
window.open('https://www.clipperz.com/pricing/', '_blank');
|
window.open('https://www.clipperz.com/pricing/', '_blank');
|
||||||
},
|
},
|
||||||
|
|
||||||
//-------------------------------------------------------------------------
|
'handlePayButton': function (anEvent) {
|
||||||
/*
|
anEvent.preventDefault();
|
||||||
'drawUserInfoBackground': function (canvas) {
|
MochiKit.Signal.signal(Clipperz.Signal.NotificationCenter, 'makePayment', anEvent);
|
||||||
var kMyDrawingFunctionWidth = 188.0;
|
|
||||||
var kMyDrawingFunctionHeight = 154.0;
|
|
||||||
|
|
||||||
var context = canvas.getContext("2d");
|
|
||||||
var color;
|
|
||||||
var resolution;
|
|
||||||
var alignStroke;
|
|
||||||
var path;
|
|
||||||
var pointX;
|
|
||||||
var pointY;
|
|
||||||
var controlPoint1X;
|
|
||||||
var controlPoint1Y;
|
|
||||||
var controlPoint2X;
|
|
||||||
var controlPoint2Y;
|
|
||||||
var gradient;
|
|
||||||
if (window.devicePixelRatio)
|
|
||||||
resolution = window.devicePixelRatio;
|
|
||||||
else
|
|
||||||
resolution = 1.0;
|
|
||||||
resolution *= 0.5 * (canvas.width / kMyDrawingFunctionWidth + canvas.height / kMyDrawingFunctionHeight);
|
|
||||||
|
|
||||||
context.save();
|
|
||||||
context.scale(canvas.width / kMyDrawingFunctionWidth, canvas.height / kMyDrawingFunctionHeight);
|
|
||||||
context.clearRect(0.0, 0.0, kMyDrawingFunctionWidth, kMyDrawingFunctionHeight);
|
|
||||||
|
|
||||||
// Setup for Shadow Effect
|
|
||||||
color = "rgba(0.0%, 0.0%, 0.0%, 0.667)";
|
|
||||||
context.save();
|
|
||||||
context.shadowColor = color;
|
|
||||||
context.shadowBlur = 3.0;
|
|
||||||
context.shadowOffsetX = 5.729 * Math.cos(7.592) * resolution;
|
|
||||||
context.shadowOffsetY = 5.729 * Math.sin(7.592) * resolution;
|
|
||||||
|
|
||||||
// Layer 1
|
|
||||||
|
|
||||||
alignStroke = 0.0;
|
|
||||||
context.beginPath();
|
|
||||||
pointX = 169.5;
|
|
||||||
pointY = 141.5;
|
|
||||||
pointX = (Math.round(resolution * pointX + alignStroke) - alignStroke) / resolution;
|
|
||||||
pointY = (Math.round(resolution * pointY + alignStroke) - alignStroke) / resolution;
|
|
||||||
context.moveTo(pointX, pointY);
|
|
||||||
pointX = 177.5;
|
|
||||||
pointY = 133.5;
|
|
||||||
pointX = (Math.round(resolution * pointX + alignStroke) - alignStroke) / resolution;
|
|
||||||
pointY = (Math.round(resolution * pointY + alignStroke) - alignStroke) / resolution;
|
|
||||||
controlPoint1X = 173.889;
|
|
||||||
controlPoint1Y = 141.5;
|
|
||||||
controlPoint1X = (Math.round(resolution * controlPoint1X + alignStroke) - alignStroke) / resolution;
|
|
||||||
controlPoint1Y = (Math.round(resolution * controlPoint1Y + alignStroke) - alignStroke) / resolution;
|
|
||||||
controlPoint2X = 177.5;
|
|
||||||
controlPoint2Y = 137.889;
|
|
||||||
controlPoint2X = (Math.round(resolution * controlPoint2X + alignStroke) - alignStroke) / resolution;
|
|
||||||
controlPoint2Y = (Math.round(resolution * controlPoint2Y + alignStroke) - alignStroke) / resolution;
|
|
||||||
context.bezierCurveTo(controlPoint1X, controlPoint1Y, controlPoint2X, controlPoint2Y, pointX, pointY);
|
|
||||||
pointX = 177.5;
|
|
||||||
pointY = 19.5;
|
|
||||||
pointX = (Math.round(resolution * pointX + alignStroke) - alignStroke) / resolution;
|
|
||||||
pointY = (Math.round(resolution * pointY + alignStroke) - alignStroke) / resolution;
|
|
||||||
context.lineTo(pointX, pointY);
|
|
||||||
pointX = 169.5;
|
|
||||||
pointY = 11.5;
|
|
||||||
pointX = (Math.round(resolution * pointX + alignStroke) - alignStroke) / resolution;
|
|
||||||
pointY = (Math.round(resolution * pointY + alignStroke) - alignStroke) / resolution;
|
|
||||||
controlPoint1X = 177.5;
|
|
||||||
controlPoint1Y = 15.111;
|
|
||||||
controlPoint1X = (Math.round(resolution * controlPoint1X + alignStroke) - alignStroke) / resolution;
|
|
||||||
controlPoint1Y = (Math.round(resolution * controlPoint1Y + alignStroke) - alignStroke) / resolution;
|
|
||||||
controlPoint2X = 173.889;
|
|
||||||
controlPoint2Y = 11.5;
|
|
||||||
controlPoint2X = (Math.round(resolution * controlPoint2X + alignStroke) - alignStroke) / resolution;
|
|
||||||
controlPoint2Y = (Math.round(resolution * controlPoint2Y + alignStroke) - alignStroke) / resolution;
|
|
||||||
context.bezierCurveTo(controlPoint1X, controlPoint1Y, controlPoint2X, controlPoint2Y, pointX, pointY);
|
|
||||||
pointX = 18.5;
|
|
||||||
pointY = 11.5;
|
|
||||||
pointX = (Math.round(resolution * pointX + alignStroke) - alignStroke) / resolution;
|
|
||||||
pointY = (Math.round(resolution * pointY + alignStroke) - alignStroke) / resolution;
|
|
||||||
context.lineTo(pointX, pointY);
|
|
||||||
pointX = 10.5;
|
|
||||||
pointY = 19.5;
|
|
||||||
pointX = (Math.round(resolution * pointX + alignStroke) - alignStroke) / resolution;
|
|
||||||
pointY = (Math.round(resolution * pointY + alignStroke) - alignStroke) / resolution;
|
|
||||||
controlPoint1X = 14.111;
|
|
||||||
controlPoint1Y = 11.5;
|
|
||||||
controlPoint1X = (Math.round(resolution * controlPoint1X + alignStroke) - alignStroke) / resolution;
|
|
||||||
controlPoint1Y = (Math.round(resolution * controlPoint1Y + alignStroke) - alignStroke) / resolution;
|
|
||||||
controlPoint2X = 10.5;
|
|
||||||
controlPoint2Y = 15.111;
|
|
||||||
controlPoint2X = (Math.round(resolution * controlPoint2X + alignStroke) - alignStroke) / resolution;
|
|
||||||
controlPoint2Y = (Math.round(resolution * controlPoint2Y + alignStroke) - alignStroke) / resolution;
|
|
||||||
context.bezierCurveTo(controlPoint1X, controlPoint1Y, controlPoint2X, controlPoint2Y, pointX, pointY);
|
|
||||||
pointX = 10.5;
|
|
||||||
pointY = 133.5;
|
|
||||||
pointX = (Math.round(resolution * pointX + alignStroke) - alignStroke) / resolution;
|
|
||||||
pointY = (Math.round(resolution * pointY + alignStroke) - alignStroke) / resolution;
|
|
||||||
context.lineTo(pointX, pointY);
|
|
||||||
pointX = 18.5;
|
|
||||||
pointY = 141.5;
|
|
||||||
pointX = (Math.round(resolution * pointX + alignStroke) - alignStroke) / resolution;
|
|
||||||
pointY = (Math.round(resolution * pointY + alignStroke) - alignStroke) / resolution;
|
|
||||||
controlPoint1X = 10.5;
|
|
||||||
controlPoint1Y = 137.889;
|
|
||||||
controlPoint1X = (Math.round(resolution * controlPoint1X + alignStroke) - alignStroke) / resolution;
|
|
||||||
controlPoint1Y = (Math.round(resolution * controlPoint1Y + alignStroke) - alignStroke) / resolution;
|
|
||||||
controlPoint2X = 14.111;
|
|
||||||
controlPoint2Y = 141.5;
|
|
||||||
controlPoint2X = (Math.round(resolution * controlPoint2X + alignStroke) - alignStroke) / resolution;
|
|
||||||
controlPoint2Y = (Math.round(resolution * controlPoint2Y + alignStroke) - alignStroke) / resolution;
|
|
||||||
context.bezierCurveTo(controlPoint1X, controlPoint1Y, controlPoint2X, controlPoint2Y, pointX, pointY);
|
|
||||||
pointX = 169.5;
|
|
||||||
pointY = 141.5;
|
|
||||||
pointX = (Math.round(resolution * pointX + alignStroke) - alignStroke) / resolution;
|
|
||||||
pointY = (Math.round(resolution * pointY + alignStroke) - alignStroke) / resolution;
|
|
||||||
context.lineTo(pointX, pointY);
|
|
||||||
context.closePath();
|
|
||||||
gradient = context.createLinearGradient(94.0, 11.5, 94.0, 141.5);
|
|
||||||
color = "#EE9B69";
|
|
||||||
gradient.addColorStop(0.0, color);
|
|
||||||
color = "#E38D62";
|
|
||||||
gradient.addColorStop(1.0, color);
|
|
||||||
context.fillStyle = gradient;
|
|
||||||
context.fill();
|
|
||||||
|
|
||||||
// Shadow Effect
|
|
||||||
context.restore();
|
|
||||||
|
|
||||||
context.restore();
|
|
||||||
},
|
},
|
||||||
*/
|
|
||||||
|
|
||||||
//-------------------------------------------------------------------------
|
//-------------------------------------------------------------------------
|
||||||
|
|
||||||
'updateUserDetails': function (someUserInfo) {
|
'updateUserDetails': function (someUserInfo) {
|
||||||
@ -360,6 +223,103 @@ Clipperz.Base.extend(Clipperz.PM.UI.Web.Components.UserInfoBox, Clipperz.PM.UI.C
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
'numberOfStarsMatchingActiveLevel': function (aValue) {
|
||||||
|
var maxLevel = 15;
|
||||||
|
var value;
|
||||||
|
var result;
|
||||||
|
|
||||||
|
value = Math.min(aValue, maxLevel);
|
||||||
|
result = value / maxLevel * 5;
|
||||||
|
|
||||||
|
return result;
|
||||||
|
},
|
||||||
|
|
||||||
|
'starsLabel': function(numberOfActiveStars) {
|
||||||
|
var result;
|
||||||
|
var i;
|
||||||
|
|
||||||
|
// "★☆☆☆"
|
||||||
|
result = "";
|
||||||
|
for (i=0; i<5; i++) {
|
||||||
|
if (i < numberOfActiveStars) {
|
||||||
|
result = result + "★";
|
||||||
|
} else {
|
||||||
|
result = result + "☆";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return result;
|
||||||
|
},
|
||||||
|
/*
|
||||||
|
'updateCurrentSubscriptionDetails': function (anAccountInfo) {
|
||||||
|
//console.log("AccountInfo", anAccountInfo);
|
||||||
|
var subscriptionLevel = anAccountInfo.latestActiveLevel();
|
||||||
|
|
||||||
|
var expireLabel;
|
||||||
|
var formattedDate;
|
||||||
|
|
||||||
|
if (anAccountInfo.expirationDate() == Clipperz.Date.distantFuture) {
|
||||||
|
formattedDate = "never";
|
||||||
|
} else {
|
||||||
|
formattedDate = Clipperz.PM.Date.formatDateWithTemplate(anAccountInfo.expirationDate(), "D, d M Y");
|
||||||
|
}
|
||||||
|
|
||||||
|
this.append(this.getElement('accountInfo'), [
|
||||||
|
{tag:'div', cls:'accountStatus', children:[
|
||||||
|
{tag:'span', cls:'label', html:"status"},
|
||||||
|
{tag:'span', cls:'status', html:anAccountInfo.status()}
|
||||||
|
]}
|
||||||
|
]);
|
||||||
|
|
||||||
|
if (anAccountInfo.isExpired()) {
|
||||||
|
expireLabel = "expired";
|
||||||
|
} else {
|
||||||
|
expireLabel = "expires";
|
||||||
|
}
|
||||||
|
|
||||||
|
this.append(this.getElement('accountInfo'), [
|
||||||
|
|
||||||
|
{tag:'div', cls:'accountLevel', children:[
|
||||||
|
{tag:'span', cls:'label', html:"level"},
|
||||||
|
{tag:'span', cls:'level', html:this.starsLabel(this.numberOfStarsMatchingActiveLevel(anAccountInfo.latestActiveThreshold()))}
|
||||||
|
]},
|
||||||
|
|
||||||
|
{tag:'div', cls:'accountExpiration', children:[
|
||||||
|
{tag:'span', cls:'label', html:expireLabel},
|
||||||
|
{tag:'span', cls:'expriation', html:formattedDate}
|
||||||
|
]}
|
||||||
|
]);
|
||||||
|
|
||||||
|
if (anAccountInfo.isExpired() || anAccountInfo.isExpiring()) {
|
||||||
|
var buttonLabel;
|
||||||
|
|
||||||
|
if (anAccountInfo.paymentVerificationPending()) {
|
||||||
|
buttonLabel = "Verify payment";
|
||||||
|
} else {
|
||||||
|
if (subscriptionLevel == 'TRIAL') {
|
||||||
|
buttonLabel = "Subscribe";
|
||||||
|
} else if (subscriptionLevel == 'EARLY_ADOPTER') {
|
||||||
|
buttonLabel = "Donate";
|
||||||
|
} else if (subscriptionLevel == 'PATRON') {
|
||||||
|
buttonLabel = "Donate";
|
||||||
|
} else if (subscriptionLevel == 'PAYMENT_PENDING') {
|
||||||
|
buttonLabel = "Verify payment";
|
||||||
|
} else {
|
||||||
|
buttonLabel = "Renew subscription";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
this.append(this.getElement('accountInfo'), [
|
||||||
|
{tag:'div', cls:'payButton', children:[
|
||||||
|
{tag:'a', href:'#', id:this.getId('payButton'), cls:'info', html:buttonLabel}
|
||||||
|
]},
|
||||||
|
]);
|
||||||
|
|
||||||
|
MochiKit.Signal.connect(this.getElement('payButton'), 'onclick', this, 'handlePayButton');
|
||||||
|
|
||||||
|
}
|
||||||
|
},
|
||||||
|
*/
|
||||||
//-------------------------------------------------------------------------
|
//-------------------------------------------------------------------------
|
||||||
__syntaxFix__: "syntax fix"
|
__syntaxFix__: "syntax fix"
|
||||||
});
|
});
|
||||||
|
@ -49,6 +49,8 @@ Clipperz.PM.UI.Web.Controllers.AppController = function(args) {
|
|||||||
// MochiKit.Signal.connect(Clipperz.Signal.NotificationCenter, 'deleteCard', this, 'handleDeleteCard');
|
// MochiKit.Signal.connect(Clipperz.Signal.NotificationCenter, 'deleteCard', this, 'handleDeleteCard');
|
||||||
|
|
||||||
MochiKit.Signal.connect(Clipperz.Signal.NotificationCenter, 'userDataSuccessfullySaved', this, 'userDataSuccessfullySavedHandler');
|
MochiKit.Signal.connect(Clipperz.Signal.NotificationCenter, 'userDataSuccessfullySaved', this, 'userDataSuccessfullySavedHandler');
|
||||||
|
// MochiKit.Signal.connect(Clipperz.Signal.NotificationCenter, 'makePayment', this, 'handlePaymentRequest');
|
||||||
|
MochiKit.Signal.connect(Clipperz.Signal.NotificationCenter, 'deleteAccount', this, 'deleteAccount');
|
||||||
|
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
@ -125,7 +127,7 @@ MochiKit.Base.update(Clipperz.PM.UI.Web.Controllers.AppController.prototype, {
|
|||||||
|
|
||||||
'accountPanel': function () {
|
'accountPanel': function () {
|
||||||
if (this._accountPanel == null) {
|
if (this._accountPanel == null) {
|
||||||
this._accountPanel = new Clipperz.PM.UI.Web.Components.AccountPanel(/*{selected:'Preferences'}*/);
|
this._accountPanel = new Clipperz.PM.UI.Web.Components.AccountPanel({credentialVefificationFunction: MochiKit.Base.bind(this.credentialVefificationFunction, this) /*, selected:'Preferences'*/});
|
||||||
}
|
}
|
||||||
|
|
||||||
return this._accountPanel;
|
return this._accountPanel;
|
||||||
@ -199,6 +201,10 @@ MochiKit.Base.update(Clipperz.PM.UI.Web.Controllers.AppController.prototype, {
|
|||||||
]
|
]
|
||||||
})
|
})
|
||||||
deferredResult.addMethod(this.userInfoBox(), 'updateUserDetails');
|
deferredResult.addMethod(this.userInfoBox(), 'updateUserDetails');
|
||||||
|
|
||||||
|
deferredResult.addMethod(this.user(), 'getCurrentAccountInfo');
|
||||||
|
// deferredResult.addMethod(this.userInfoBox(), 'updateCurrentSubscriptionDetails');
|
||||||
|
|
||||||
deferredResult.callback(this.user());
|
deferredResult.callback(this.user());
|
||||||
|
|
||||||
return deferredResult;
|
return deferredResult;
|
||||||
@ -343,6 +349,64 @@ MochiKit.Base.update(Clipperz.PM.UI.Web.Controllers.AppController.prototype, {
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
//=============================================================================
|
||||||
|
/*
|
||||||
|
'handlePaymentRequest': function (anEvent) {
|
||||||
|
var deferredResult;
|
||||||
|
var paymentController;
|
||||||
|
|
||||||
|
console.log("AppController - handlePaymentRequest", anEvent);
|
||||||
|
paymentController = new Clipperz.PM.UI.Web.Controllers.PaymentController({delegate:this});
|
||||||
|
deferredResult = paymentController.run(anEvent.src());
|
||||||
|
|
||||||
|
return deferredResult;
|
||||||
|
},
|
||||||
|
|
||||||
|
'subscriptionOptions': function () {
|
||||||
|
return this.user().connection().message('subscriptionOptions');
|
||||||
|
},
|
||||||
|
|
||||||
|
'getPaymentSubscriptionInfo': function () {
|
||||||
|
return this.user().connection().message('paymentRequest');
|
||||||
|
},
|
||||||
|
|
||||||
|
'getPaymentAddress': function (aCurrency, aLevel, aSubscription) {
|
||||||
|
return this.user().connection().message('paymentAddress', { subscription:aSubscription, currency:aCurrency, level:aLevel });
|
||||||
|
},
|
||||||
|
*/
|
||||||
|
//=============================================================================
|
||||||
|
|
||||||
|
'credentialVefificationFunction': function (someCredentials) {
|
||||||
|
var result;
|
||||||
|
var deferredPassphrase;
|
||||||
|
|
||||||
|
result = false;
|
||||||
|
|
||||||
|
deferredPassphrase = this.user().getPassphrase();
|
||||||
|
if (deferredPassphrase.state() == 'success') {
|
||||||
|
result = (someCredentials['passphrase'] == deferredPassphrase.results[0]);
|
||||||
|
}
|
||||||
|
|
||||||
|
result = result && (someCredentials['username'] == this.user().username());
|
||||||
|
|
||||||
|
return result;
|
||||||
|
},
|
||||||
|
|
||||||
|
'deleteAccount': function (someCredentials) {
|
||||||
|
if (this.credentialVefificationFunction(someCredentials)) {
|
||||||
|
var deferredResult;
|
||||||
|
|
||||||
|
deferredResult = new Clipperz.Async.Deferred("AppController.deleteAccount", {trace:false});
|
||||||
|
deferredResult.addMethod(this.user(), 'deleteAccount');
|
||||||
|
deferredResult.addCallback(MochiKit.Signal.signal, this, 'logout');
|
||||||
|
deferredResult.addErrback(function (anError) {
|
||||||
|
console.log("ERROR", anError);
|
||||||
|
});
|
||||||
|
|
||||||
|
deferredResult.callback();
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
//=============================================================================
|
//=============================================================================
|
||||||
__syntaxFix__: "syntax fix"
|
__syntaxFix__: "syntax fix"
|
||||||
});
|
});
|
||||||
|
@ -394,6 +394,9 @@ Clipperz.Base.extend(Clipperz.PM.UI.Web.Controllers.CardDialogController, Object
|
|||||||
|
|
||||||
window.open(url);
|
window.open(url);
|
||||||
break;
|
break;
|
||||||
|
case 'BITCOIN':
|
||||||
|
window.open(someValues['value']);
|
||||||
|
break;
|
||||||
case 'EMAIL':
|
case 'EMAIL':
|
||||||
var url;
|
var url;
|
||||||
|
|
||||||
|
@ -190,7 +190,7 @@ MochiKit.Base.update(Clipperz.PM.UI.Web.Controllers.MainController.prototype, {
|
|||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
|
|
||||||
'handleLogout': function(anEvent) {
|
'handleLogout': function(anEvent) {
|
||||||
this.exit('logout.html');
|
this.exit('exit.html');
|
||||||
},
|
},
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
|
@ -320,6 +320,7 @@ MochiKit.Base.update(Clipperz.PM.UI.Web.Controllers.NewUserWizardController.prot
|
|||||||
|
|
||||||
'done': function () {
|
'done': function () {
|
||||||
this.doneWithRuler();
|
this.doneWithRuler();
|
||||||
|
this.user().resetAllData();
|
||||||
MochiKit.Signal.signal(this, 'done', {'user': this.user()});
|
MochiKit.Signal.signal(this, 'done', {'user': this.user()});
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -0,0 +1,111 @@
|
|||||||
|
/*
|
||||||
|
|
||||||
|
Copyright 2008-2013 Clipperz Srl
|
||||||
|
|
||||||
|
This file is part of Clipperz, the online password manager.
|
||||||
|
For further information about its features and functionalities please
|
||||||
|
refer to http://www.clipperz.com.
|
||||||
|
|
||||||
|
* Clipperz 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.
|
||||||
|
|
||||||
|
* Clipperz 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 Clipperz. If not, see http://www.gnu.org/licenses/.
|
||||||
|
|
||||||
|
*/
|
||||||
|
|
||||||
|
Clipperz.Base.module('Clipperz.PM.UI.Web.Controllers');
|
||||||
|
|
||||||
|
Clipperz.PM.UI.Web.Controllers.PaymentController = function(args) {
|
||||||
|
Clipperz.PM.UI.Web.Controllers.PaymentController.superclass.constructor.apply(this, arguments);
|
||||||
|
|
||||||
|
this._delegate = args['delegate'];
|
||||||
|
this._referenceElement = null;
|
||||||
|
this._paymentComponent = null;
|
||||||
|
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
//MochiKit.Base.update(Clipperz.PM.UI.Web.Controllers.AppController.prototype, {
|
||||||
|
Clipperz.Base.extend(Clipperz.PM.UI.Web.Controllers.PaymentController, Object, {
|
||||||
|
|
||||||
|
'toString': function() {
|
||||||
|
return "Clipperz.PM.UI.Web.Controllers.PaymentController";
|
||||||
|
},
|
||||||
|
|
||||||
|
'delegate': function () {
|
||||||
|
return this._delegate;
|
||||||
|
},
|
||||||
|
|
||||||
|
//-------------------------------------------------------------------------
|
||||||
|
|
||||||
|
'referenceElement': function () {
|
||||||
|
return this._referenceElement;
|
||||||
|
},
|
||||||
|
|
||||||
|
'setReferenceElement': function (anElement) {
|
||||||
|
this._referenceElement = anElement;
|
||||||
|
},
|
||||||
|
|
||||||
|
//-------------------------------------------------------------------------
|
||||||
|
|
||||||
|
'paymentComponent': function () {
|
||||||
|
if (this._paymentComponent == null) {
|
||||||
|
var paymentComponent = new Clipperz.PM.UI.Web.Components.PaymentComponent();
|
||||||
|
|
||||||
|
MochiKit.Signal.connect(paymentComponent, 'cancel', this, 'handleCancel');
|
||||||
|
MochiKit.Signal.connect(paymentComponent, 'pay', this, 'handlePaymentRequest');
|
||||||
|
|
||||||
|
this._paymentComponent = paymentComponent;
|
||||||
|
}
|
||||||
|
|
||||||
|
return this._paymentComponent;
|
||||||
|
},
|
||||||
|
|
||||||
|
//-------------------------------------------------------------------------
|
||||||
|
|
||||||
|
'run': function (anElement) {
|
||||||
|
var deferredResult;
|
||||||
|
|
||||||
|
this.setReferenceElement(anElement);
|
||||||
|
|
||||||
|
deferredResult = new Clipperz.Async.Deferred("PaymentController.run", {trace:false});
|
||||||
|
deferredResult.addMethod(this.paymentComponent(), 'deferredShowModal', {openFromElement:this.referenceElement()});
|
||||||
|
deferredResult.addMethod(this.delegate(), 'subscriptionOptions');
|
||||||
|
deferredResult.addMethod(this.paymentComponent(), 'setSubscriptionOptions');
|
||||||
|
deferredResult.callback();
|
||||||
|
|
||||||
|
return deferredResult;
|
||||||
|
},
|
||||||
|
|
||||||
|
//=============================================================================
|
||||||
|
|
||||||
|
'handlePaymentRequest': function (someOptions) {
|
||||||
|
console.log("PaymentController - handlePaymentRequest", someOptions['currency'], someOptions['type']);
|
||||||
|
var deferredResult;
|
||||||
|
|
||||||
|
deferredResult = new Clipperz.Async.Deferred("PaymentController.handlePaymentRequest", {trace:false});
|
||||||
|
deferredResult.addMethod(this.delegate(), 'getPaymentSubscriptionInfo');
|
||||||
|
deferredResult.addCallback(function (subscriptionOptions) { return subscriptionOptions['subscription']});
|
||||||
|
deferredResult.addMethod(this.delegate(), 'getPaymentAddress', someOptions['currency'], someOptions['type']);
|
||||||
|
deferredResult.addMethod(this.paymentComponent(), 'showQrCode');
|
||||||
|
// deferredResult.addCallback(function (subscriptionInfo) { console.log("SUBSCRIPTION INFO", subscriptionInfo); });
|
||||||
|
deferredResult.callback();
|
||||||
|
|
||||||
|
return deferredResult;
|
||||||
|
},
|
||||||
|
|
||||||
|
'handleCancel': function (anEvent) {
|
||||||
|
console.log("PaymentController - handleCancel");
|
||||||
|
},
|
||||||
|
|
||||||
|
//=============================================================================
|
||||||
|
__syntaxFix__: "syntax fix"
|
||||||
|
});
|
@ -82,6 +82,7 @@
|
|||||||
|
|
||||||
"Clipperz/PM/DataModel/EncryptedRemoteObject.js",
|
"Clipperz/PM/DataModel/EncryptedRemoteObject.js",
|
||||||
"Clipperz/PM/DataModel/User.js",
|
"Clipperz/PM/DataModel/User.js",
|
||||||
|
"Clipperz/PM/DataModel/User.AccountInfo.js",
|
||||||
"Clipperz/PM/DataModel/User.Header.Legacy.js",
|
"Clipperz/PM/DataModel/User.Header.Legacy.js",
|
||||||
"Clipperz/PM/DataModel/User.Header.RecordIndex.js",
|
"Clipperz/PM/DataModel/User.Header.RecordIndex.js",
|
||||||
"Clipperz/PM/DataModel/User.Header.Preferences.js",
|
"Clipperz/PM/DataModel/User.Header.Preferences.js",
|
||||||
@ -171,6 +172,7 @@
|
|||||||
"Clipperz/PM/UI/Web/Components/UnlockPasswordComponent.js",
|
"Clipperz/PM/UI/Web/Components/UnlockPasswordComponent.js",
|
||||||
"Clipperz/PM/UI/Web/Components/NewUserCreationComponent.js",
|
"Clipperz/PM/UI/Web/Components/NewUserCreationComponent.js",
|
||||||
"Clipperz/PM/UI/Web/Components/PasswordTooltip.js",
|
"Clipperz/PM/UI/Web/Components/PasswordTooltip.js",
|
||||||
|
"Clipperz/PM/UI/Web/Components/PaymentComponent.js",
|
||||||
|
|
||||||
"Clipperz/PM/UI/Web/Controllers/MainController.js",
|
"Clipperz/PM/UI/Web/Controllers/MainController.js",
|
||||||
"Clipperz/PM/UI/Web/Controllers/LoginController.js",
|
"Clipperz/PM/UI/Web/Controllers/LoginController.js",
|
||||||
@ -182,6 +184,7 @@
|
|||||||
"Clipperz/PM/UI/Web/Controllers/CardDialogController.js",
|
"Clipperz/PM/UI/Web/Controllers/CardDialogController.js",
|
||||||
"Clipperz/PM/UI/Web/Controllers/DirectLoginWizardController.js",
|
"Clipperz/PM/UI/Web/Controllers/DirectLoginWizardController.js",
|
||||||
"Clipperz/PM/UI/Web/Controllers/NewUserWizardController.js",
|
"Clipperz/PM/UI/Web/Controllers/NewUserWizardController.js",
|
||||||
|
"Clipperz/PM/UI/Web/Controllers/PaymentController.js",
|
||||||
|
|
||||||
"main.js"
|
"main.js"
|
||||||
],
|
],
|
||||||
|
@ -336,6 +336,27 @@ var tests = {
|
|||||||
*/
|
*/
|
||||||
},
|
},
|
||||||
|
|
||||||
|
//-------------------------------------------------------------------------
|
||||||
|
|
||||||
|
'Clipperz.Base.isBitcoin_test': function () {
|
||||||
|
var bitcoinTestCases;
|
||||||
|
|
||||||
|
bitcoinTestCases = [
|
||||||
|
{url:'bitcoin:175tWpb8K1S7NmH4Zx6rewF9WQrcZv245W?amount=20.3&label=Luke-Jr', expectedResult:true},
|
||||||
|
{url:'bitcoin:175tWpb8K1S7NmH4Zx6rewF9WQrcZv245W', expectedResult:true},
|
||||||
|
|
||||||
|
{url:'http://www.clipperz.com', expectedResult:false},
|
||||||
|
{url:'http://clipperz.com', expectedResult:false},
|
||||||
|
{}
|
||||||
|
];
|
||||||
|
|
||||||
|
MochiKit.Base.map(function (someValues) {
|
||||||
|
if (typeof(someValues['url']) != 'undefined') {
|
||||||
|
SimpleTest.is(Clipperz.Base.isBitcoin(someValues['url']), someValues['expectedResult'], "testing url '" + someValues['url'] + "' - expected result: " + someValues['expectedResult']);
|
||||||
|
}
|
||||||
|
}, bitcoinTestCases);
|
||||||
|
},
|
||||||
|
|
||||||
//-------------------------------------------------------------------------
|
//-------------------------------------------------------------------------
|
||||||
|
|
||||||
'Clipperz.Base.isEmail_test': function () {
|
'Clipperz.Base.isEmail_test': function () {
|
||||||
|
@ -73,6 +73,7 @@ refer to http://www.clipperz.com.
|
|||||||
<script type='text/javascript' src='../../../../../js/Clipperz/PM/DataModel/User.Header.Preferences.js'></script>
|
<script type='text/javascript' src='../../../../../js/Clipperz/PM/DataModel/User.Header.Preferences.js'></script>
|
||||||
<script type='text/javascript' src='../../../../../js/Clipperz/PM/DataModel/User.Header.OneTimePasswords.js'></script>
|
<script type='text/javascript' src='../../../../../js/Clipperz/PM/DataModel/User.Header.OneTimePasswords.js'></script>
|
||||||
<script type='text/javascript' src='../../../../../js/Clipperz/PM/DataModel/OneTimePassword.js'></script>
|
<script type='text/javascript' src='../../../../../js/Clipperz/PM/DataModel/OneTimePassword.js'></script>
|
||||||
|
<script type='text/javascript' src='../../../../../js/Clipperz/PM/DataModel/User.AccountInfo.js'></script>
|
||||||
|
|
||||||
<script type="text/javascript" src="../../../../SimpleTest/SimpleTest.Async.js"></script>
|
<script type="text/javascript" src="../../../../SimpleTest/SimpleTest.Async.js"></script>
|
||||||
<script>
|
<script>
|
||||||
|
@ -75,6 +75,7 @@ refer to http://www.clipperz.com.
|
|||||||
<script type='text/javascript' src='../../../../../js/Clipperz/PM/DataModel/User.Header.Preferences.js'></script>
|
<script type='text/javascript' src='../../../../../js/Clipperz/PM/DataModel/User.Header.Preferences.js'></script>
|
||||||
<script type='text/javascript' src='../../../../../js/Clipperz/PM/DataModel/User.Header.OneTimePasswords.js'></script>
|
<script type='text/javascript' src='../../../../../js/Clipperz/PM/DataModel/User.Header.OneTimePasswords.js'></script>
|
||||||
<script type='text/javascript' src='../../../../../js/Clipperz/PM/DataModel/OneTimePassword.js'></script>
|
<script type='text/javascript' src='../../../../../js/Clipperz/PM/DataModel/OneTimePassword.js'></script>
|
||||||
|
<script type='text/javascript' src='../../../../../js/Clipperz/PM/DataModel/User.AccountInfo.js'></script>
|
||||||
|
|
||||||
<script type="text/javascript" src="../../../../SimpleTest/SimpleTest.Async.js"></script>
|
<script type="text/javascript" src="../../../../SimpleTest/SimpleTest.Async.js"></script>
|
||||||
<script>
|
<script>
|
||||||
|
@ -77,6 +77,7 @@ refer to http://www.clipperz.com.
|
|||||||
<script type='text/javascript' src='../../../../../js/Clipperz/PM/DataModel/User.Header.Preferences.js'></script>
|
<script type='text/javascript' src='../../../../../js/Clipperz/PM/DataModel/User.Header.Preferences.js'></script>
|
||||||
<script type='text/javascript' src='../../../../../js/Clipperz/PM/DataModel/User.Header.OneTimePasswords.js'></script>
|
<script type='text/javascript' src='../../../../../js/Clipperz/PM/DataModel/User.Header.OneTimePasswords.js'></script>
|
||||||
<script type='text/javascript' src='../../../../../js/Clipperz/PM/DataModel/OneTimePassword.js'></script>
|
<script type='text/javascript' src='../../../../../js/Clipperz/PM/DataModel/OneTimePassword.js'></script>
|
||||||
|
<script type='text/javascript' src='../../../../../js/Clipperz/PM/DataModel/User.AccountInfo.js'></script>
|
||||||
|
|
||||||
<script type="text/javascript" src="../../../../SimpleTest/SimpleTest.Async.js"></script>
|
<script type="text/javascript" src="../../../../SimpleTest/SimpleTest.Async.js"></script>
|
||||||
</head>
|
</head>
|
||||||
|
@ -76,6 +76,7 @@ refer to http://www.clipperz.com.
|
|||||||
<script type='text/javascript' src='../../../../../js/Clipperz/PM/DataModel/User.Header.Preferences.js'></script>
|
<script type='text/javascript' src='../../../../../js/Clipperz/PM/DataModel/User.Header.Preferences.js'></script>
|
||||||
<script type='text/javascript' src='../../../../../js/Clipperz/PM/DataModel/User.Header.OneTimePasswords.js'></script>
|
<script type='text/javascript' src='../../../../../js/Clipperz/PM/DataModel/User.Header.OneTimePasswords.js'></script>
|
||||||
<script type='text/javascript' src='../../../../../js/Clipperz/PM/DataModel/OneTimePassword.js'></script>
|
<script type='text/javascript' src='../../../../../js/Clipperz/PM/DataModel/OneTimePassword.js'></script>
|
||||||
|
<script type='text/javascript' src='../../../../../js/Clipperz/PM/DataModel/User.AccountInfo.js'></script>
|
||||||
|
|
||||||
<script type="text/javascript" src="../../../../SimpleTest/SimpleTest.Async.js"></script>
|
<script type="text/javascript" src="../../../../SimpleTest/SimpleTest.Async.js"></script>
|
||||||
<script>
|
<script>
|
||||||
|
@ -128,18 +128,9 @@ class FrontendBuilder(object):
|
|||||||
def loadFilesContent (self, basePath, files):
|
def loadFilesContent (self, basePath, files):
|
||||||
result = ""
|
result = ""
|
||||||
|
|
||||||
# for file in self.filterFiles(files):
|
fileContent = self.loadIndividualFilesContent(basePath, files)
|
||||||
# try:
|
for file in self.filterFiles(files):
|
||||||
# fileHandler = codecs.open(self.absolutePathForSourceFile(basePath, file), 'r', 'utf-8')
|
result += fileContent[file] + '\n'
|
||||||
# except:
|
|
||||||
# print "FILE: " + file
|
|
||||||
#
|
|
||||||
# result += fileHandler.read() + '\n'
|
|
||||||
# fileHandler.close()
|
|
||||||
|
|
||||||
# for name, content in self.loadIndividualFilesContent(basePath, files):
|
|
||||||
for name, content in list(self.loadIndividualFilesContent(basePath, files).items()):
|
|
||||||
result += content + '\n'
|
|
||||||
|
|
||||||
return result
|
return result
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user