132 lines
5.8 KiB
JavaScript
132 lines
5.8 KiB
JavaScript
define([
|
||
'jquery',
|
||
'/common/hyperscript.js',
|
||
'/customize/messages.js',
|
||
'/customize/application_config.js',
|
||
'/common/outer/local-store.js',
|
||
'/customize/pages.js',
|
||
'/api/config',
|
||
], function ($, h, Msg, AppConfig, LocalStore, Pages, Config) {
|
||
var origin = encodeURIComponent(window.location.hostname);
|
||
var accounts = {
|
||
donateURL: AppConfig.donateURL || "https://opencollective.com/cryptpad/",
|
||
upgradeURL: AppConfig.upgradeURL || 'https://accounts.cryptpad.fr/#/?on=' + origin,
|
||
};
|
||
return function () {
|
||
Msg.features_f_apps_note = AppConfig.availablePadTypes.map(function (app) {
|
||
if (AppConfig.registeredOnlyTypes.indexOf(app) !== -1) { return; }
|
||
return Msg.type[app];
|
||
}).filter(function (x) { return x; }).join(', ');
|
||
var premiumButton = h('a', {
|
||
href: accounts.upgradeURL,
|
||
target: '_blank',
|
||
rel: 'noopener noreferrer'
|
||
}, h('button.cp-features-register-button', Msg.features_f_subscribe));
|
||
|
||
var anonymousFeatures =
|
||
h('div.col-12.col-sm-4.cp-anon-user',[
|
||
h('div.card',[
|
||
h('div.card-body',[
|
||
h('h3.text-center',Msg.features_anon)
|
||
]),
|
||
h('div.card-body.cp-pricing',[
|
||
h('div.text-center', '0€'),
|
||
h('div.text-center', Msg.features_noData),
|
||
]),
|
||
h('ul.list-group.list-group-flush',
|
||
['apps', 'core', 'file0', 'cryptdrive0', 'storage0'].map(function (f) {
|
||
return h('li.list-group-item', [
|
||
h('div.cp-check'),
|
||
h('div.cp-content', [
|
||
h('div.cp-feature', Msg['features_f_' + f]),
|
||
h('div.cp-note', Msg['features_f_' + f + '_note'])
|
||
])
|
||
]);
|
||
})
|
||
),
|
||
]),
|
||
]);
|
||
var registeredFeatures =
|
||
h('div.col-12.col-sm-4.cp-regis-user',[
|
||
h('div.card',[
|
||
h('div.card-body',[
|
||
h('h3.text-center',Msg.features_registered)
|
||
]),
|
||
h('div.card-body.cp-pricing',[
|
||
h('div.text-center', '0€'),
|
||
h('div.text-center', Msg.features_noData),
|
||
]),
|
||
h('ul.list-group.list-group-flush', [
|
||
['anon', 'social', 'file1', 'cryptdrive1', 'devices', 'storage1'].map(function (f) {
|
||
return h('li.list-group-item', [
|
||
h('div.cp-check'),
|
||
h('div.cp-content', [
|
||
h('div.cp-feature', Msg['features_f_' + f]),
|
||
h('div.cp-note', Msg['features_f_' + f + '_note'])
|
||
])
|
||
]);
|
||
}),
|
||
]),
|
||
h('div.card-body',[
|
||
h('div.cp-features-register#cp-features-register', [
|
||
h('a', {
|
||
href: '/register/'
|
||
}, h('button.cp-features-register-button', Msg.features_f_register))
|
||
]),
|
||
h('div.cp-note', Msg.features_f_register_note)
|
||
]),
|
||
]),
|
||
]);
|
||
var premiumFeatures =
|
||
h('div.col-12.col-sm-4.cp-anon-user',[
|
||
h('div.card',[
|
||
h('div.card-body',[
|
||
h('h3.text-center',Msg.features_premium)
|
||
]),
|
||
h('div.card-body.cp-pricing',[
|
||
h('div.text-center', h('a', {
|
||
href: accounts.upgradeURL,
|
||
target: '_blank'
|
||
}, Msg._getKey('features_pricing', ['5', '10', '15']))),
|
||
h('div.text-center', Msg.features_emailRequired),
|
||
]),
|
||
h('ul.list-group.list-group-flush', [
|
||
['reg', 'storage2', 'support', 'supporter'].map(function (f) {
|
||
return h('li.list-group-item', [
|
||
h('div.cp-check'),
|
||
h('div.cp-content', [
|
||
h('div.cp-feature', Msg['features_f_' + f]),
|
||
h('div.cp-note', Msg['features_f_' + f + '_note'])
|
||
])
|
||
]);
|
||
}),
|
||
]),
|
||
h('div.card-body',[
|
||
h('div.cp-features-register#cp-features-subscribe', [
|
||
premiumButton
|
||
]),
|
||
LocalStore.isLoggedIn() ? undefined : h('div.cp-note', Msg.features_f_subscribe_note)
|
||
]),
|
||
]),
|
||
]);
|
||
var availableFeatures =
|
||
Config.allowSubscriptions ?
|
||
[anonymousFeatures, registeredFeatures, premiumFeatures] :
|
||
[anonymousFeatures, registeredFeatures];
|
||
|
||
return h('div#cp-main', [
|
||
Pages.infopageTopbar(),
|
||
h('div.container-fluid.cp_cont_features',[
|
||
h('div.container',[
|
||
h('center', h('h1', Msg.features_title)),
|
||
]),
|
||
]),
|
||
h('div.container', [
|
||
h('div.row.cp-container.cp-features-web.justify-content-sm-center', availableFeatures),
|
||
]),
|
||
Pages.infopageFooter()
|
||
]);
|
||
};
|
||
});
|
||
|