diff options
author | Julius Härtl <jus@bitgrid.net> | 2019-01-23 16:34:56 +0100 |
---|---|---|
committer | Julius Härtl <jus@bitgrid.net> | 2019-03-01 20:56:17 +0100 |
commit | 7843b8b1fa4dff3d3d4fac0fb81f144e5df1e34f (patch) | |
tree | 91f6d3e0ce782b439c5a0f4b77b916b0636c2359 /core/src/OCP | |
parent | 51057c539feace8381ab83310b307749fec60f91 (diff) | |
download | nextcloud-server-7843b8b1fa4dff3d3d4fac0fb81f144e5df1e34f.tar.gz nextcloud-server-7843b8b1fa4dff3d3d4fac0fb81f144e5df1e34f.zip |
Adjust OCP.Collaboration
Signed-off-by: Julius Härtl <jus@bitgrid.net>
Diffstat (limited to 'core/src/OCP')
-rw-r--r-- | core/src/OCP/collaboration.js | 156 |
1 files changed, 27 insertions, 129 deletions
diff --git a/core/src/OCP/collaboration.js b/core/src/OCP/collaboration.js index a4b0fc24e66..a74834e741e 100644 --- a/core/src/OCP/collaboration.js +++ b/core/src/OCP/collaboration.js @@ -20,144 +20,42 @@ * */ -let resourceSelectHandlers = {}; - -export default { - - /** - * @class - * @param resourceType - * @param resourceId - * @constructor - */ - Resource: function(resourceType, resourceId) { - this.resourceType = '' + resourceType; - this.resourceId = '' + resourceId; - }, - - /** - * @class - * @param id - * @param name - * @constructor - */ - Collection: function(id, name) { - this.id = '' + id; - this.name = '' + name; - this.resources = []; - }, - - /** - * - * @param resourceType - * @param title - * @param selectorCallback - */ - registerResourceSelector: function(resourceType, title, selectorCallback) { - if (!this.resourceSelectHandlers.hasOwnProperty(resourceType)) { - this.resourceSelectHandlers[resourceType] = { - title: title, - callback: selectorCallback - }; - } - }, +/** + * @typedef TypeDefinition + * @method {callback} action This action is executed to let the user select a resource + * @param {string} icon Contains the icon css class for the type + * @constructor + */ - getResourceTypes: function() { - return this.resourceSelectHandlers; - }, +/** + * @type {TypeDefinition[]} + **/ +let types = {}; +export default { /** - * Select a resource for a given type * - * @param resourceType - * @param successCallback - * @param abortCallback + * @param type + * @param {TypeDefinition} typeDefinition */ - selectResource: function (resourceType, successCallback, abortCallback) { - this.resourceSelectHandlers[resourceType].callback(successCallback, abortCallback); + registerType(type, typeDefinition) { + console.log('Type ' + type + ' registered') + types[type] = typeDefinition; }, - - getCollectionsByResource: function(resourceType, resourceId) { - // TODO: to implement + trigger(type) { + return types[type].action() }, - - /** - * Create a new collection from two resources - * - * @param name - * @param resource1 - * @param resource2 - * @param successCallback - * @param errorCallback - */ - createCollection: function (name, resource1, resource2, successCallback, errorCallback) { - var self = this; - this.createCollectionOnResource(name, resource1, function (collection) { - self.addResource(collection, resource2, function (collection) { - successCallback(collection); - }) - }); + getTypes() { + return Object.keys(types); }, - - /** - * - * @param name - * @param resource1 - * @param successCallback - * @param errorCallback - */ - createCollectionOnResource: function (name, resource1, successCallback, errorCallback) { - var data = { - name: name, - resourceType: resource1.resourceType, - resourceId: ''+resource1.resourceId, - }; - var request = new XMLHttpRequest(); - request.open('POST', OC.linkToOCS('collaboration/resources/' + data.resourceType, 2) + data.resourceId + '?format=json', true); - request.setRequestHeader('Content-Type', 'application/json; charset=UTF-8'); - request.setRequestHeader('oc_requesttoken', OC.requestToken); - request.setRequestHeader('OCS-APIRequest', true); - request.onreadystatechange = function () { - if(request.readyState === 4 && request.status === 200) { - var result = JSON.parse(request.responseText); - var collection = new OCP.Collaboration.Collection(result.ocs.data.id, result.ocs.data.name); - collection.resources.push(resource1); - successCallback(collection); - } - }; - request.send(JSON.stringify(data)); + getIcon(type) { + return types[type].icon; }, - - /** - * Add a resource to a collection - * - * @param {OCP.Collaboration.Collection} collection - * @param resource - * @param successCallback - * @param resource - */ - addResource: function (collection, resource, successCallback) { - var data = { - resourceType: resource.resourceType, - resourceId: '' + resource.resourceId, - }; - var request = new XMLHttpRequest(); - request.open('POST', OC.linkToOCS('collaboration/resources/collections', 2) + collection.id + '?format=json', true); - request.setRequestHeader('Content-Type', 'application/json; charset=UTF-8'); - request.setRequestHeader('oc_requesttoken', OC.requestToken); - request.setRequestHeader('OCS-APIRequest', true); - request.onreadystatechange = function () { - if(request.readyState === 4 && request.status === 200) { - var result = JSON.parse(request.responseText); - collection.resources.push(resource); - successCallback(collection); - } - }; - request.send(JSON.stringify(data)); + getLabel(type) { + return t('files_sharing', 'Link to a {label}', { label: types[type].typeString || type }, 1) }, - - removeResource: function(collection, resource) { - // TODO: to implement + getLink(type, id) { + /* TODO: Allow action to be executed instead of href as well */ + return typeof types[type] !== 'undefined' ? types[type].link(id) : ''; } - }; |