mirror of https://github.com/xwiki-labs/cryptpad
209 lines
7.9 KiB
JavaScript
209 lines
7.9 KiB
JavaScript
// SPDX-FileCopyrightText: 2023 XWiki CryptPad Team <contact@cryptpad.org> and contributors
|
||
//
|
||
// SPDX-License-Identifier: AGPL-3.0-or-later
|
||
|
||
define([
|
||
'jquery',
|
||
'/common/common-util.js',
|
||
'/common/common-hash.js',
|
||
'/common/common-interface.js',
|
||
'/common/common-ui-elements.js',
|
||
'/common/inner/common-modal.js',
|
||
'/common/hyperscript.js',
|
||
'/customize/messages.js',
|
||
'/components/nthen/index.js',
|
||
], function ($, Util, Hash, UI, UIElements, Modal, h,
|
||
Messages, nThen) {
|
||
var Properties = {};
|
||
|
||
var getPadProperties = function (Env, data, opts, _cb) {
|
||
var cb = Util.once(Util.mkAsync(_cb));
|
||
var common = Env.common;
|
||
opts = opts || {};
|
||
var $d = $('<div>');
|
||
if (!data) { return void cb(void 0, $d); }
|
||
data = Util.clone(data);
|
||
|
||
var privateData = common.getMetadataMgr().getPrivateData();
|
||
if (privateData.propChannels) {
|
||
var p = privateData.propChannels;
|
||
data.channel = data.channel || p.channel;
|
||
data.answersChannel = data.answersChannel || p.answersChannel;
|
||
data.rtChannel = data.rtChannel || p.rtChannel;
|
||
data.lastVersion = data.lastVersion || p.lastVersion;
|
||
data.lastCpHash = data.lastCpHash || p.lastCpHash;
|
||
}
|
||
|
||
if (data.channel) {
|
||
$('<label>', { 'for': 'cp-app-prop-id'}).text(Messages.documentID).appendTo($d);
|
||
$d.append(UI.dialog.selectable(data.channel, {
|
||
id: 'cp-app-prop-id',
|
||
}));
|
||
}
|
||
|
||
if (data.href) {
|
||
$('<label>', {'for': 'cp-app-prop-link'}).text(Messages.editShare).appendTo($d);
|
||
$d.append(UI.dialog.selectable(data.href, {
|
||
id: 'cp-app-prop-link',
|
||
}));
|
||
}
|
||
|
||
if (data.roHref && !opts.noReadOnly) {
|
||
$('<label>', {'for': 'cp-app-prop-rolink'}).text(Messages.viewShare).appendTo($d);
|
||
$d.append(UI.dialog.selectable(data.roHref, {
|
||
id: 'cp-app-prop-rolink',
|
||
}));
|
||
}
|
||
|
||
if (data.tags && Array.isArray(data.tags)) {
|
||
$d.append(h('div.cp-app-prop', [Messages.fm_prop_tagsList, h('br'), h('span.cp-app-prop-content', data.tags.join(', '))]));
|
||
}
|
||
|
||
if (data.ctime) {
|
||
$d.append(h('div.cp-app-prop', [Messages.fm_creation, h('br'), h('span.cp-app-prop-content', new Date(data.ctime).toLocaleString())]));
|
||
}
|
||
|
||
if (data.atime) {
|
||
$d.append(h('div.cp-app-prop', [Messages.fm_lastAccess, h('br'), h('span.cp-app-prop-content', new Date(data.atime).toLocaleString())]));
|
||
}
|
||
|
||
if (!common.isLoggedIn()) { return void cb(void 0, $d); }
|
||
|
||
if (privateData.offline) { return void cb(void 0, $d); }
|
||
|
||
// File and history size...
|
||
var owned = Modal.isOwned(Env, data);
|
||
|
||
// check the size of this file, including additional channels
|
||
var bytes = 0;
|
||
var historyBytes;
|
||
var chan = [data.channel];
|
||
if (data.answersChannel) { chan.push(data.answersChannel); }
|
||
if (data.rtChannel) { chan.push(data.rtChannel); }
|
||
if (data.lastVersion) { chan.push(Hash.hrefToHexChannelId(data.lastVersion)); }
|
||
|
||
// Get the channels with history (no blobs)
|
||
var channels = chan.filter(function (c) { return c.length === 32; }).map(function (id) {
|
||
if (id === data.rtChannel && data.lastVersion && data.lastCpHash) {
|
||
return {
|
||
channel: id,
|
||
lastKnownHash: data.lastCpHash
|
||
};
|
||
}
|
||
return {
|
||
channel: id
|
||
};
|
||
});
|
||
|
||
var history = common.makeUniversal('history');
|
||
var trimChannels = [];
|
||
nThen(function (waitFor) {
|
||
// Get total size
|
||
chan.forEach(function (c) {
|
||
common.getFileSize(c, waitFor(function (e, _bytes) {
|
||
if (e) {
|
||
// there was a problem with the RPC
|
||
console.error(e);
|
||
}
|
||
bytes += _bytes;
|
||
}), true);
|
||
});
|
||
|
||
if (!owned) { return; }
|
||
// Get history size
|
||
history.execCommand('GET_HISTORY_SIZE', {
|
||
pad: true,
|
||
channels: channels,
|
||
teamId: typeof(owned) === "number" && owned
|
||
}, waitFor(function (obj) {
|
||
if (obj && obj.error) { return; }
|
||
historyBytes = obj.size;
|
||
trimChannels = obj.channels;
|
||
}));
|
||
}).nThen(function () {
|
||
if (bytes === 0) { return void cb(void 0, $d); }
|
||
var formatted = UIElements.prettySize(bytes);
|
||
|
||
if (!owned || !historyBytes || historyBytes > bytes || historyBytes < 0) {
|
||
$d.append(h('div.cp-app-prop', [
|
||
Messages.upload_size,
|
||
h('br'),
|
||
h('span.cp-app-prop-content', formatted)
|
||
]));
|
||
return void cb(void 0, $d);
|
||
}
|
||
|
||
|
||
var p = Math.round((historyBytes / bytes) * 100);
|
||
var historyPrettySize = UIElements.prettySize(historyBytes);
|
||
var contentsPrettySize = UIElements.prettySize(bytes - historyBytes);
|
||
var button;
|
||
var spinner = UI.makeSpinner();
|
||
var size = h('div.cp-app-prop', [
|
||
Messages.upload_size,
|
||
h('br'),
|
||
h('div.cp-app-prop-size-container', [
|
||
h('div.cp-app-prop-size-history', { style: 'width:'+p+'%;' })
|
||
]),
|
||
h('div.cp-app-prop-size-legend', [
|
||
h('div.cp-app-prop-history-size', [
|
||
h('span.cp-app-prop-history-size-color'),
|
||
h('span.cp-app-prop-content', Messages._getKey('historyTrim_historySize', [historyPrettySize]))
|
||
]),
|
||
h('div.cp-app-prop-contents-size', [
|
||
h('span.cp-app-prop-contents-size-color'),
|
||
h('span.cp-app-prop-content', Messages._getKey('historyTrim_contentsSize', [contentsPrettySize]))
|
||
]),
|
||
]),
|
||
button = h('button.btn.btn-danger-alt.no-margin', Messages.trimHistory_button),
|
||
spinner.spinner
|
||
]);
|
||
$d.append(size);
|
||
|
||
var $button = $(button);
|
||
UI.confirmButton(button, {
|
||
classes: 'btn-danger'
|
||
}, function () {
|
||
$button.remove();
|
||
spinner.spin();
|
||
history.execCommand('TRIM_HISTORY', {
|
||
pad: true,
|
||
channels: trimChannels,
|
||
teamId: typeof(owned) === "number" && owned
|
||
}, function (obj) {
|
||
spinner.hide();
|
||
if (obj && obj.error || obj.warning) {
|
||
console.error(obj.warning);
|
||
$(size).append(h('div.alert.alert-danger', Messages.trimHistory_error));
|
||
return;
|
||
}
|
||
$(size).remove();
|
||
var formatted = UIElements.prettySize(bytes - historyBytes);
|
||
$d.append(h('div.cp-app-prop', [
|
||
Messages.upload_size,
|
||
h('br'),
|
||
h('span.cp-app-prop-content', formatted)
|
||
]));
|
||
$d.append(h('div.alert.alert-success', Messages.trimHistory_success));
|
||
});
|
||
});
|
||
|
||
cb(void 0, $d);
|
||
});
|
||
};
|
||
|
||
Properties.getPropertiesModal = function (common, opts, cb) {
|
||
cb = cb || function () {};
|
||
opts = opts || {};
|
||
opts.access = true;
|
||
var tabs = [{
|
||
getTab: getPadProperties,
|
||
title: Messages.fc_prop,
|
||
icon: "fa fa-info-circle",
|
||
}];
|
||
Modal.getModal(common, opts, tabs, cb);
|
||
};
|
||
|
||
return Properties;
|
||
});
|