Added more columns to ext storage list
Now using system mount and personal mount calls to get the relevant mount points including backend information.
This commit is contained in:
parent
a47ef52ae2
commit
710d017eec
|
@ -29,8 +29,16 @@
|
||||||
_createRow: function(fileData) {
|
_createRow: function(fileData) {
|
||||||
// TODO: hook earlier and render the whole row here
|
// TODO: hook earlier and render the whole row here
|
||||||
var $tr = OCA.Files.FileList.prototype._createRow.apply(this, arguments);
|
var $tr = OCA.Files.FileList.prototype._createRow.apply(this, arguments);
|
||||||
|
var $scopeColumn = $('<td></td>');
|
||||||
|
var $backendColumn = $('<td></td>');
|
||||||
|
var scopeText = t('files_external', 'Personal');
|
||||||
|
if (fileData.scope === 'system') {
|
||||||
|
scopeText = t('files_external', 'System');
|
||||||
|
}
|
||||||
$tr.find('.filesize,.date').remove();
|
$tr.find('.filesize,.date').remove();
|
||||||
$tr.find('td.filename').after('<td></td>');
|
$scopeColumn.text(scopeText);
|
||||||
|
$backendColumn.text(fileData.backend);
|
||||||
|
$tr.find('td.filename').after($scopeColumn).after($backendColumn);
|
||||||
$tr.find('td.filename input:checkbox').remove();
|
$tr.find('td.filename input:checkbox').remove();
|
||||||
return $tr;
|
return $tr;
|
||||||
},
|
},
|
||||||
|
|
|
@ -24,6 +24,39 @@ namespace OCA\Files\External;
|
||||||
|
|
||||||
class Api {
|
class Api {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Formats the given mount config to a mount entry.
|
||||||
|
*
|
||||||
|
* @param bool $isSystemMount true for system mount, false
|
||||||
|
* for personal mount
|
||||||
|
*
|
||||||
|
* @return array entry
|
||||||
|
*/
|
||||||
|
private static function formatMount($mountConfig, $isSystemMount = false) {
|
||||||
|
// split user name from mount point
|
||||||
|
$path = dirname($mountConfig['mountpoint']);
|
||||||
|
if ($path === '.') {
|
||||||
|
$path = '';
|
||||||
|
}
|
||||||
|
|
||||||
|
$permissions = \OCP\PERMISSION_READ;
|
||||||
|
// personal mounts can be deleted
|
||||||
|
if (!$isSystemMount) {
|
||||||
|
$permissions |= \OCP\PERMISSION_DELETE;
|
||||||
|
}
|
||||||
|
|
||||||
|
// TODO: add storageType, might need to use another OC_Mount_Config method
|
||||||
|
$entry = array(
|
||||||
|
'name' => basename($mountConfig['mountpoint']),
|
||||||
|
'path' => $path,
|
||||||
|
'type' => 'dir',
|
||||||
|
'backend' => $mountConfig['backend'],
|
||||||
|
'scope' => ( $isSystemMount ? 'system' : 'personal' ),
|
||||||
|
'permissions' => $permissions
|
||||||
|
);
|
||||||
|
return $entry;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the mount points visible for this user.
|
* Returns the mount points visible for this user.
|
||||||
*
|
*
|
||||||
|
@ -33,30 +66,16 @@ class Api {
|
||||||
public static function getUserMounts($params) {
|
public static function getUserMounts($params) {
|
||||||
$entries = array();
|
$entries = array();
|
||||||
$user = \OC_User::getUser();
|
$user = \OC_User::getUser();
|
||||||
$mounts = \OC_Mount_Config::getAbsoluteMountPoints($user);
|
|
||||||
|
|
||||||
foreach ($mounts as $mountPoint => $config) {
|
$personalMounts = \OC_Mount_Config::getPersonalMountPoints();
|
||||||
// split user name from mount point
|
$systemMounts = \OC_Mount_Config::getSystemMountPoints();
|
||||||
$parts = explode('/', ltrim($mountPoint, '/'));
|
|
||||||
array_shift($parts); // use name
|
|
||||||
array_shift($parts); // files
|
|
||||||
$mountPoint = implode('/', $parts);
|
|
||||||
|
|
||||||
$path = dirname($mountPoint);
|
foreach ($systemMounts as $mountConfig) {
|
||||||
if ($path === '.') {
|
$entries[] = self::formatMount($mountConfig, true);
|
||||||
$path = '';
|
}
|
||||||
}
|
|
||||||
|
|
||||||
// TODO: give delete permissions if mount type is personal
|
foreach ($personalMounts as $mountConfig) {
|
||||||
$permissions = \OCP\PERMISSION_READ;
|
$entries[] = self::formatMount($mountConfig, false);
|
||||||
|
|
||||||
// TODO: add storageType, might need to use another OC_Mount_Config method
|
|
||||||
$entries[] = array(
|
|
||||||
'name' => basename($mountPoint),
|
|
||||||
'path' => $path,
|
|
||||||
'type' => 'dir',
|
|
||||||
'permissions' => $permissions
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return new \OC_OCS_Result($entries);
|
return new \OC_OCS_Result($entries);
|
||||||
|
|
|
@ -16,6 +16,12 @@
|
||||||
<a class="name sort columntitle" data-sort="name"><span><?php p($l->t( 'Name' )); ?></span><span class="sort-indicator"></span></a>
|
<a class="name sort columntitle" data-sort="name"><span><?php p($l->t( 'Name' )); ?></span><span class="sort-indicator"></span></a>
|
||||||
</div>
|
</div>
|
||||||
</th>
|
</th>
|
||||||
|
<th id="headerBackend" class="hidden column-backend">
|
||||||
|
<a class="backend sort columntitle" data-sort="backend"><span><?php p($l->t('Storage type')); ?></span><span class="sort-indicator"></span></a>
|
||||||
|
</th>
|
||||||
|
<th id="headerScope" class="hidden column-size">
|
||||||
|
<a class="scope sort columntitle" data-sort="scope"><span><?php p($l->t('Scope')); ?></span><span class="sort-indicator"></span></a>
|
||||||
|
</th>
|
||||||
</tr>
|
</tr>
|
||||||
</thead>
|
</thead>
|
||||||
<tbody id="fileList">
|
<tbody id="fileList">
|
||||||
|
|
Loading…
Reference in New Issue