@contentstack/management
Version:
The Content Management API is used to manage the content of your Contentstack account
94 lines (89 loc) • 3.01 kB
JavaScript
import cloneDeep from 'lodash/cloneDeep';
import { update, deleteEntity, fetch, create } from '../../../entity';
/**
* Folders refer to Asset Folders.
* @namespace Folder
*/
export function Folder(http) {
var data = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
if (data.stackHeaders) {
this.stackHeaders = data.stackHeaders;
}
this.urlPath = "/assets/folders";
if (data.asset) {
Object.assign(this, cloneDeep(data.asset));
this.urlPath = "/assets/folders/".concat(this.uid);
/**
* @description The Update Folder call lets you update the name and description of an existing Folder.
* @memberof Folder
* @func update
* @returns {Promise<Folder>} Promise for Folder instance
* @example
* import * as contentstack from '@contentstack/management'
* const client = contentstack.client()
*
* client.stack({ api_key: 'api_key'}).asset().folder('uid').fetch()
* .then((folder) => {
* folder.name = 'My New folder'
* return folder.update()
* })
* .then((folder) => console.log(folder))
*
*/
this.update = update(http, 'asset');
/**
* @description The Delete folder call deletes an existing folder from the stack.
* @memberof Folder
* @func delete
* @returns {Promise<Object>} Response Object.
* @example
* import * as contentstack from '@contentstack/management'
* const client = contentstack.client()
*
* client.stack({ api_key: 'api_key'}).asset().folder('uid').delete()
* .then((response) => console.log(response.notice))
*/
this["delete"] = deleteEntity(http);
/**
* @description The fetch folder call returns comprehensive information about a specific folder.
* @memberof Folder
* @func fetch
* @returns {Promise<Folder>} Promise for Folder instance
* @example
* import * as contentstack from '@contentstack/management'
* const client = contentstack.client()
*
* client.stack({ api_key: 'api_key'}).asset().folder('uid').fetch()
* .then((folder) => console.log(folder))
*
*/
this.fetch = fetch(http, 'asset');
} else {
/**
* @description The Create a folder call creates a new folder in the assets.
* @memberof Folder
* @func create
* @returns {Promise<Folder>} Promise for Folder instance
*
* @example
* import * as contentstack from '@contentstack/management'
* const client = contentstack.client()
* const asset = {name: 'My New Folder'}
* client.stack().asset().folder().create({ asset })
* .then((folder) => console.log(folder))
*/
this.create = create({
http: http
});
}
}
export function FolderCollection(http, data) {
var obj = cloneDeep(data.assets) || [];
var assetCollection = obj.map(function (userdata) {
return new Folder(http, {
asset: userdata,
stackHeaders: data.stackHeaders
});
});
return assetCollection;
}