features.opensocial-reference.mediaitem.js Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of shindig-features Show documentation
Show all versions of shindig-features Show documentation
Packages all the features that shindig provides into a single jar file to allow
loading from the classpath
The newest version!
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
/*global opensocial */
/**
* @class
* Represents images, movies, and audio.
* Create a MediaItem
object using the
*
* opensocial.newMediaItem() method.
*
* @name opensocial.MediaItem
*/
/**
* Represents images, movies, and audio.
*
* @param {string} mimeType The media's type
* @param {string} url The media's location
* @param {Object.=} opt_params
* Any other fields that should be set on the media item object.
* All of the defined Fields are supported.
* @constructor
* @private
*/
opensocial.MediaItem = function(mimeType, url, opt_params) {
this.fields_ = {};
if (opt_params) {
for (var k in opt_params) {
if (opt_params.hasOwnProperty(k)) {
this.fields_[k] = opt_params[k];
}
}
}
this.fields_[opensocial.MediaItem.Field.MIME_TYPE] = mimeType;
this.fields_[opensocial.MediaItem.Field.URL] = url;
};
/**
* @static
* @class
* The possible types of media items.
*
*
* See also:
*
* opensocial.MediaItem.Field
*
*
* @name opensocial.MediaItem.Type
* @enum {string}
* @const
*/
opensocial.MediaItem.Type = {
/** @member opensocial.MediaItem.Type */
IMAGE : 'image',
/** @member opensocial.MediaItem.Type */
VIDEO : 'video',
/** @member opensocial.MediaItem.Type */
AUDIO : 'audio'
};
/**
* @static
* @class
* All of the fields that media items have.
*
*
* See also:
*
* opensocial.MediaItem.getField()
*
*
* @name opensocial.MediaItem.Field
*/
opensocial.MediaItem.Field = {
/**
* The type of media, specified as a
*
* MediaItem.Type
object.
* @member opensocial.MediaItem.Field
*/
TYPE : 'type',
/**
* The MIME type of media, specified as a String.
* @member opensocial.MediaItem.Field
*/
MIME_TYPE : 'mimeType',
/**
* A string specifying the URL where the media can be found.
* @member opensocial.MediaItem.Field
*/
URL : 'url'
};
/**
* Gets the media item data that's associated with the specified key.
*
* @param {string} key The key to get data for; see the
* Field class
* for possible values
* @return {string} The data
*/
opensocial.MediaItem.prototype.getField = function(key, opt_params) {
return opensocial.Container.getField(this.fields_, key, opt_params);
};
/**
* Sets data for this media item associated with the given key.
*
* @param {string} key The key to set data for
* @param {string} data The data to set
*/
opensocial.MediaItem.prototype.setField = function(key, data) {
return (this.fields_[key] = data);
};
© 2015 - 2024 Weber Informatics LLC | Privacy Policy