| Index: chrome/browser/resources/quota_internals/event_handler.js
|
| diff --git a/chrome/browser/resources/quota_internals/event_handler.js b/chrome/browser/resources/quota_internals/event_handler.js
|
| index 89fe3559a8c0a824e0c6ee825e8630d994fbfed6..59607dbdef66f720f61987197c47b43089413154 100644
|
| --- a/chrome/browser/resources/quota_internals/event_handler.js
|
| +++ b/chrome/browser/resources/quota_internals/event_handler.js
|
| @@ -10,64 +10,64 @@
|
| // require cr/util.js
|
|
|
| (function() {
|
| -'use strict';
|
| + 'use strict';
|
|
|
| -/**
|
| + /**
|
| * @param {Object} object Object to be checked.
|
| * @return {boolean} true if |object| is {}.
|
| * @private
|
| */
|
| -function isEmptyObject_(object) {
|
| - for (var i in object)
|
| - return false;
|
| - return true;
|
| -}
|
| + function isEmptyObject_(object) {
|
| + for (var i in object)
|
| + return false;
|
| + return true;
|
| + }
|
|
|
| -/**
|
| + /**
|
| * Copy properties from |source| to |destination|.
|
| * @param {Object} source Source of the copy.
|
| * @param {Object} destination Destination of the copy.
|
| * @return {Object} |destination|.
|
| * @private
|
| */
|
| -function copyAttributes_(source, destination) {
|
| - for (var i in source)
|
| - destination[i] = source[i];
|
| - return destination;
|
| -}
|
| -
|
| -/**
|
| - * Apply localization to |element| with i18n_template.js if available.
|
| - * @param {Element} element Element to be localized.
|
| - * @private
|
| - */
|
| -function localize_(element) {
|
| - if (window.i18nTemplate && window.loadTimeData)
|
| - i18nTemplate.process(element, loadTimeData);
|
| -}
|
| + function copyAttributes_(source, destination) {
|
| + for (var i in source)
|
| + destination[i] = source[i];
|
| + return destination;
|
| + }
|
| +
|
| + /**
|
| + * Apply localization to |element| with i18n_template.js if available.
|
| + * @param {Element} element Element to be localized.
|
| + * @private
|
| + */
|
| + function localize_(element) {
|
| + if (window.i18nTemplate && window.loadTimeData)
|
| + i18nTemplate.process(element, loadTimeData);
|
| + }
|
|
|
| -/**
|
| + /**
|
| * Returns 'N/A' (Not Available) text if |value| is undefined.
|
| * @param {Object} value Object to print.
|
| * @return {string} 'N/A' or ''.
|
| * @private
|
| */
|
| -function checkIfAvailable_(value) {
|
| - return value === undefined ? 'N/A' : '';
|
| -}
|
| + function checkIfAvailable_(value) {
|
| + return value === undefined ? 'N/A' : '';
|
| + }
|
|
|
| -/**
|
| + /**
|
| * Returns |value| itself if |value| is not undefined,
|
| * else returns 'N/A' text.
|
| * @param {?string} value String to print.
|
| * @return {string} 'N/A' or |value|.
|
| * @private
|
| */
|
| -function stringToText_(value) {
|
| - return checkIfAvailable_(value) || value;
|
| -}
|
| + function stringToText_(value) {
|
| + return checkIfAvailable_(value) || value;
|
| + }
|
|
|
| -/**
|
| + /**
|
| * Separates |value| into segments.
|
| * The length of first segment is at most |maxLength|.
|
| * Length of other following segments are just |maxLength|.
|
| @@ -77,17 +77,17 @@ function stringToText_(value) {
|
| * @return {Array<string>} Array of segments.
|
| * @private
|
| */
|
| -function separateBackward_(value, maxLength) {
|
| - var result = [];
|
| - while (value.length > maxLength) {
|
| - result.unshift(value.slice(-3));
|
| - value = value.slice(0, -3);
|
| + function separateBackward_(value, maxLength) {
|
| + var result = [];
|
| + while (value.length > maxLength) {
|
| + result.unshift(value.slice(-3));
|
| + value = value.slice(0, -3);
|
| + }
|
| + result.unshift(value);
|
| + return result;
|
| }
|
| - result.unshift(value);
|
| - return result;
|
| -}
|
|
|
| -/**
|
| + /**
|
| * Returns formatted string from number as number of bytes.
|
| * e.g. numBytesToText(123456789) = '123.45 MB (123,456,789 B)'.
|
| * If |value| is undefined, this function returns 'N/A'.
|
| @@ -95,25 +95,25 @@ function separateBackward_(value, maxLength) {
|
| * @return {string} 'N/A' or formatted |value|.
|
| * @private
|
| */
|
| -function numBytesToText_(value) {
|
| - var result = checkIfAvailable_(value);
|
| - if (result)
|
| - return result;
|
| -
|
| - var segments = separateBackward_(value.toString(), 3);
|
| - result = segments.join(',') + ' B';
|
| + function numBytesToText_(value) {
|
| + var result = checkIfAvailable_(value);
|
| + if (result)
|
| + return result;
|
| +
|
| + var segments = separateBackward_(value.toString(), 3);
|
| + result = segments.join(',') + ' B';
|
| +
|
| + if (segments.length > 1) {
|
| + var UNIT = [' B', ' KB', ' MB', ' GB', ' TB', ' PB'];
|
| + result = segments[0] + '.' + segments[1].slice(0, 2) +
|
| + UNIT[Math.min(segments.length, UNIT.length) - 1] + ' (' + result +
|
| + ')';
|
| + }
|
|
|
| - if (segments.length > 1) {
|
| - var UNIT = [' B', ' KB', ' MB', ' GB', ' TB', ' PB'];
|
| - result = segments[0] + '.' + segments[1].slice(0, 2) +
|
| - UNIT[Math.min(segments.length, UNIT.length) - 1] +
|
| - ' (' + result + ')';
|
| + return result;
|
| }
|
|
|
| - return result;
|
| -}
|
| -
|
| -/**
|
| + /**
|
| * Return formatted date |value| if |value| is not undefined.
|
| * If |value| is undefined, this function returns 'N/A'.
|
| * @param {?number} value Number of milliseconds since
|
| @@ -121,121 +121,117 @@ function numBytesToText_(value) {
|
| * @return {string} Formatted text of date or 'N/A'.
|
| * @private
|
| */
|
| -function dateToText(value) {
|
| - var result = checkIfAvailable_(value);
|
| - if (result)
|
| - return result;
|
| + function dateToText(value) {
|
| + var result = checkIfAvailable_(value);
|
| + if (result)
|
| + return result;
|
| +
|
| + var time = new Date(value);
|
| + var now = new Date();
|
| + var delta = Date.now() - value;
|
| +
|
| + var SECOND = 1000;
|
| + var MINUTE = 60 * SECOND;
|
| + var HOUR = 60 * MINUTE;
|
| + var DAY = 23 * HOUR;
|
| + var WEEK = 7 * DAY;
|
| +
|
| + var SHOW_SECOND = 5 * MINUTE;
|
| + var SHOW_MINUTE = 5 * HOUR;
|
| + var SHOW_HOUR = 3 * DAY;
|
| + var SHOW_DAY = 2 * WEEK;
|
| + var SHOW_WEEK = 3 * 30 * DAY;
|
| +
|
| + if (delta < 0) {
|
| + result = 'access from future ';
|
| + } else if (delta < SHOW_SECOND) {
|
| + result = Math.ceil(delta / SECOND) + ' sec ago ';
|
| + } else if (delta < SHOW_MINUTE) {
|
| + result = Math.ceil(delta / MINUTE) + ' min ago ';
|
| + } else if (delta < SHOW_HOUR) {
|
| + result = Math.ceil(delta / HOUR) + ' hr ago ';
|
| + } else if (delta < SHOW_WEEK) {
|
| + result = Math.ceil(delta / DAY) + ' day ago ';
|
| + }
|
|
|
| - var time = new Date(value);
|
| - var now = new Date();
|
| - var delta = Date.now() - value;
|
| -
|
| - var SECOND = 1000;
|
| - var MINUTE = 60 * SECOND;
|
| - var HOUR = 60 * MINUTE;
|
| - var DAY = 23 * HOUR;
|
| - var WEEK = 7 * DAY;
|
| -
|
| - var SHOW_SECOND = 5 * MINUTE;
|
| - var SHOW_MINUTE = 5 * HOUR;
|
| - var SHOW_HOUR = 3 * DAY;
|
| - var SHOW_DAY = 2 * WEEK;
|
| - var SHOW_WEEK = 3 * 30 * DAY;
|
| -
|
| - if (delta < 0) {
|
| - result = 'access from future ';
|
| - } else if (delta < SHOW_SECOND) {
|
| - result = Math.ceil(delta / SECOND) + ' sec ago ';
|
| - } else if (delta < SHOW_MINUTE) {
|
| - result = Math.ceil(delta / MINUTE) + ' min ago ';
|
| - } else if (delta < SHOW_HOUR) {
|
| - result = Math.ceil(delta / HOUR) + ' hr ago ';
|
| - } else if (delta < SHOW_WEEK) {
|
| - result = Math.ceil(delta / DAY) + ' day ago ';
|
| + result += '(' + time.toString() + ')';
|
| + return result;
|
| }
|
|
|
| - result += '(' + time.toString() + ')';
|
| - return result;
|
| -}
|
| -
|
| -/**
|
| - * Available disk space.
|
| - * @type {number|undefined}
|
| - */
|
| -var availableSpace = undefined;
|
| + /**
|
| + * Available disk space.
|
| + * @type {number|undefined}
|
| + */
|
| + var availableSpace = undefined;
|
|
|
| -/**
|
| - * Root of the quota data tree,
|
| - * holding userdata as |treeViewObject.detail|.
|
| - * @type {cr.ui.Tree}
|
| - */
|
| -var treeViewObject = undefined;
|
| + /**
|
| + * Root of the quota data tree,
|
| + * holding userdata as |treeViewObject.detail|.
|
| + * @type {cr.ui.Tree}
|
| + */
|
| + var treeViewObject = undefined;
|
|
|
| -/**
|
| - * Key-value styled statistics data.
|
| - * This WebUI does not touch contents, just show.
|
| - * The value is hold as |statistics[key].detail|.
|
| - * @type {Object<string,Element>}
|
| - */
|
| -var statistics = {};
|
| + /**
|
| + * Key-value styled statistics data.
|
| + * This WebUI does not touch contents, just show.
|
| + * The value is hold as |statistics[key].detail|.
|
| + * @type {Object<string,Element>}
|
| + */
|
| + var statistics = {};
|
|
|
| -/**
|
| + /**
|
| * Initialize and return |treeViewObject|.
|
| * @return {cr.ui.Tree} Initialized |treeViewObject|.
|
| */
|
| -function getTreeViewObject() {
|
| - if (!treeViewObject) {
|
| - treeViewObject = $('tree-view');
|
| - cr.ui.decorate(treeViewObject, cr.ui.Tree);
|
| - treeViewObject.detail = {payload: {}, children: {}};
|
| - treeViewObject.addEventListener('change', updateDescription);
|
| + function getTreeViewObject() {
|
| + if (!treeViewObject) {
|
| + treeViewObject = $('tree-view');
|
| + cr.ui.decorate(treeViewObject, cr.ui.Tree);
|
| + treeViewObject.detail = {payload: {}, children: {}};
|
| + treeViewObject.addEventListener('change', updateDescription);
|
| + }
|
| + return treeViewObject;
|
| }
|
| - return treeViewObject;
|
| -}
|
|
|
| -/**
|
| + /**
|
| * Initialize and return a tree item, that represents specified storage type.
|
| * @param {!string} type Storage type.
|
| * @return {cr.ui.TreeItem} Initialized |storageObject|.
|
| */
|
| -function getStorageObject(type) {
|
| - var treeViewObject = getTreeViewObject();
|
| - var storageObject = treeViewObject.detail.children[type];
|
| - if (!storageObject) {
|
| - storageObject = new cr.ui.TreeItem({
|
| - label: type,
|
| - detail: {payload: {}, children: {}}
|
| - });
|
| - storageObject.mayHaveChildren_ = true;
|
| - treeViewObject.detail.children[type] = storageObject;
|
| - treeViewObject.add(storageObject);
|
| + function getStorageObject(type) {
|
| + var treeViewObject = getTreeViewObject();
|
| + var storageObject = treeViewObject.detail.children[type];
|
| + if (!storageObject) {
|
| + storageObject = new cr.ui.TreeItem(
|
| + {label: type, detail: {payload: {}, children: {}}});
|
| + storageObject.mayHaveChildren_ = true;
|
| + treeViewObject.detail.children[type] = storageObject;
|
| + treeViewObject.add(storageObject);
|
| + }
|
| + return storageObject;
|
| }
|
| - return storageObject;
|
| -}
|
|
|
| -/**
|
| + /**
|
| * Initialize and return a tree item, that represents specified
|
| * storage type and hostname.
|
| * @param {!string} type Storage type.
|
| * @param {!string} host Hostname.
|
| * @return {cr.ui.TreeItem} Initialized |hostObject|.
|
| */
|
| -function getHostObject(type, host) {
|
| - var storageObject = getStorageObject(type);
|
| - var hostObject = storageObject.detail.children[host];
|
| - if (!hostObject) {
|
| - hostObject = new cr.ui.TreeItem({
|
| - label: host,
|
| - detail: {payload: {}, children: {}}
|
| - });
|
| - hostObject.mayHaveChildren_ = true;
|
| - storageObject.detail.children[host] = hostObject;
|
| - storageObject.add(hostObject);
|
| + function getHostObject(type, host) {
|
| + var storageObject = getStorageObject(type);
|
| + var hostObject = storageObject.detail.children[host];
|
| + if (!hostObject) {
|
| + hostObject = new cr.ui.TreeItem(
|
| + {label: host, detail: {payload: {}, children: {}}});
|
| + hostObject.mayHaveChildren_ = true;
|
| + storageObject.detail.children[host] = hostObject;
|
| + storageObject.add(hostObject);
|
| + }
|
| + return hostObject;
|
| }
|
| - return hostObject;
|
| -}
|
|
|
| -/**
|
| + /**
|
| * Initialize and return a tree item, that represents specified
|
| * storage type, hostname and origin url.
|
| * @param {!string} type Storage type.
|
| @@ -243,294 +239,278 @@ function getHostObject(type, host) {
|
| * @param {!string} origin Origin URL.
|
| * @return {cr.ui.TreeItem} Initialized |originObject|.
|
| */
|
| -function getOriginObject(type, host, origin) {
|
| - var hostObject = getHostObject(type, host);
|
| - var originObject = hostObject.detail.children[origin];
|
| - if (!originObject) {
|
| - originObject = new cr.ui.TreeItem({
|
| - label: origin,
|
| - detail: {payload: {}, children: {}}
|
| - });
|
| - originObject.mayHaveChildren_ = false;
|
| - hostObject.detail.children[origin] = originObject;
|
| - hostObject.add(originObject);
|
| + function getOriginObject(type, host, origin) {
|
| + var hostObject = getHostObject(type, host);
|
| + var originObject = hostObject.detail.children[origin];
|
| + if (!originObject) {
|
| + originObject = new cr.ui.TreeItem(
|
| + {label: origin, detail: {payload: {}, children: {}}});
|
| + originObject.mayHaveChildren_ = false;
|
| + hostObject.detail.children[origin] = originObject;
|
| + hostObject.add(originObject);
|
| + }
|
| + return originObject;
|
| }
|
| - return originObject;
|
| -}
|
| -
|
| -/**
|
| - * Event Handler for |cr.quota.onAvailableSpaceUpdated|.
|
| - * |event.detail| contains |availableSpace|.
|
| - * |availableSpace| represents total available disk space.
|
| - * @param {CustomEvent} event AvailableSpaceUpdated event.
|
| - */
|
| -function handleAvailableSpace(event) {
|
| - /**
|
| - * @type {string}
|
| - */
|
| - availableSpace = event.detail;
|
| - $('diskspace-entry').innerHTML = numBytesToText_(availableSpace);
|
| -};
|
| -
|
| -/**
|
| - * Event Handler for |cr.quota.onGlobalInfoUpdated|.
|
| - * |event.detail| contains a record which has:
|
| - * |type|:
|
| - * Storage type, that is either 'temporary' or 'persistent'.
|
| - * |usage|:
|
| - * Total storage usage of all hosts.
|
| - * |unlimitedUsage|:
|
| - * Total storage usage of unlimited-quota origins.
|
| - * |quota|:
|
| - * Total quota of the storage.
|
| - *
|
| - * |usage|, |unlimitedUsage| and |quota| can be missing,
|
| - * and some additional fields can be included.
|
| - * @param {CustomEvent} event GlobalInfoUpdated event.
|
| - */
|
| -function handleGlobalInfo(event) {
|
| +
|
| /**
|
| - * @type {{
|
| - * type: {!string},
|
| - * usage: {?number},
|
| - * unlimitedUsage: {?number}
|
| - * quota: {?string}
|
| - * }}
|
| + * Event Handler for |cr.quota.onAvailableSpaceUpdated|.
|
| + * |event.detail| contains |availableSpace|.
|
| + * |availableSpace| represents total available disk space.
|
| + * @param {CustomEvent} event AvailableSpaceUpdated event.
|
| */
|
| - var data = event.detail;
|
| - var storageObject = getStorageObject(data.type);
|
| - copyAttributes_(data, storageObject.detail.payload);
|
| - storageObject.reveal();
|
| - if (getTreeViewObject().selectedItem == storageObject)
|
| - updateDescription();
|
| -
|
| -};
|
| -
|
| -/**
|
| - * Event Handler for |cr.quota.onPerHostInfoUpdated|.
|
| - * |event.detail| contains records which have:
|
| - * |host|:
|
| - * Hostname of the entry. (e.g. 'example.com')
|
| - * |type|:
|
| - * Storage type. 'temporary' or 'persistent'
|
| - * |usage|:
|
| - * Total storage usage of the host.
|
| - * |quota|:
|
| - * Per-host quota.
|
| - *
|
| - * |usage| and |quota| can be missing,
|
| - * and some additional fields can be included.
|
| - * @param {CustomEvent} event PerHostInfoUpdated event.
|
| - */
|
| -function handlePerHostInfo(event) {
|
| + function handleAvailableSpace(event) {
|
| + /**
|
| + * @type {string}
|
| + */
|
| + availableSpace = event.detail;
|
| + $('diskspace-entry').innerHTML = numBytesToText_(availableSpace);
|
| + };
|
| +
|
| /**
|
| - * @type {Array<{
|
| - * host: {!string},
|
| - * type: {!string},
|
| - * usage: {?number},
|
| - * quota: {?number}
|
| - * }}
|
| + * Event Handler for |cr.quota.onGlobalInfoUpdated|.
|
| + * |event.detail| contains a record which has:
|
| + * |type|:
|
| + * Storage type, that is either 'temporary' or 'persistent'.
|
| + * |usage|:
|
| + * Total storage usage of all hosts.
|
| + * |unlimitedUsage|:
|
| + * Total storage usage of unlimited-quota origins.
|
| + * |quota|:
|
| + * Total quota of the storage.
|
| + *
|
| + * |usage|, |unlimitedUsage| and |quota| can be missing,
|
| + * and some additional fields can be included.
|
| + * @param {CustomEvent} event GlobalInfoUpdated event.
|
| */
|
| - var dataArray = event.detail;
|
| -
|
| - for (var i = 0; i < dataArray.length; ++i) {
|
| - var data = dataArray[i];
|
| - var hostObject = getHostObject(data.type, data.host);
|
| - copyAttributes_(data, hostObject.detail.payload);
|
| - hostObject.reveal();
|
| - if (getTreeViewObject().selectedItem == hostObject)
|
| + function handleGlobalInfo(event) {
|
| + /**
|
| + * @type {{
|
| + * type: {!string},
|
| + * usage: {?number},
|
| + * unlimitedUsage: {?number}
|
| + * quota: {?string}
|
| + * }}
|
| + */
|
| + var data = event.detail;
|
| + var storageObject = getStorageObject(data.type);
|
| + copyAttributes_(data, storageObject.detail.payload);
|
| + storageObject.reveal();
|
| + if (getTreeViewObject().selectedItem == storageObject)
|
| updateDescription();
|
| + };
|
|
|
| + /**
|
| + * Event Handler for |cr.quota.onPerHostInfoUpdated|.
|
| + * |event.detail| contains records which have:
|
| + * |host|:
|
| + * Hostname of the entry. (e.g. 'example.com')
|
| + * |type|:
|
| + * Storage type. 'temporary' or 'persistent'
|
| + * |usage|:
|
| + * Total storage usage of the host.
|
| + * |quota|:
|
| + * Per-host quota.
|
| + *
|
| + * |usage| and |quota| can be missing,
|
| + * and some additional fields can be included.
|
| + * @param {CustomEvent} event PerHostInfoUpdated event.
|
| + */
|
| + function handlePerHostInfo(event) {
|
| + /**
|
| + * @type {Array<{
|
| + * host: {!string},
|
| + * type: {!string},
|
| + * usage: {?number},
|
| + * quota: {?number}
|
| + * }}
|
| + */
|
| + var dataArray = event.detail;
|
| +
|
| + for (var i = 0; i < dataArray.length; ++i) {
|
| + var data = dataArray[i];
|
| + var hostObject = getHostObject(data.type, data.host);
|
| + copyAttributes_(data, hostObject.detail.payload);
|
| + hostObject.reveal();
|
| + if (getTreeViewObject().selectedItem == hostObject)
|
| + updateDescription();
|
| + }
|
| }
|
| -}
|
| -
|
| -/**
|
| - * Event Handler for |cr.quota.onPerOriginInfoUpdated|.
|
| - * |event.detail| contains records which have:
|
| - * |origin|:
|
| - * Origin URL of the entry.
|
| - * |type|:
|
| - * Storage type of the entry. 'temporary' or 'persistent'.
|
| - * |host|:
|
| - * Hostname of the entry.
|
| - * |inUse|:
|
| - * true if the origin is in use.
|
| - * |usedCount|:
|
| - * Used count of the storage from the origin.
|
| - * |lastAccessTime|:
|
| - * Last storage access time from the origin.
|
| - * Number of milliseconds since UNIX epoch (Jan 1, 1970, 0:00:00 UTC).
|
| - * |lastModifiedTime|:
|
| - * Last modified time of the storage from the origin.
|
| - * Number of milliseconds since UNIX epoch.
|
| - *
|
| - * |inUse|, |usedCount|, |lastAccessTime| and |lastModifiedTime| can be missing,
|
| - * and some additional fields can be included.
|
| - * @param {CustomEvent} event PerOriginInfoUpdated event.
|
| - */
|
| -function handlePerOriginInfo(event) {
|
| +
|
| /**
|
| - * @type {Array<{
|
| - * origin: {!string},
|
| - * type: {!string},
|
| - * host: {!string},
|
| - * inUse: {?boolean},
|
| - * usedCount: {?number},
|
| - * lastAccessTime: {?number}
|
| - * lastModifiedTime: {?number}
|
| - * }>}
|
| + * Event Handler for |cr.quota.onPerOriginInfoUpdated|.
|
| + * |event.detail| contains records which have:
|
| + * |origin|:
|
| + * Origin URL of the entry.
|
| + * |type|:
|
| + * Storage type of the entry. 'temporary' or 'persistent'.
|
| + * |host|:
|
| + * Hostname of the entry.
|
| + * |inUse|:
|
| + * true if the origin is in use.
|
| + * |usedCount|:
|
| + * Used count of the storage from the origin.
|
| + * |lastAccessTime|:
|
| + * Last storage access time from the origin.
|
| + * Number of milliseconds since UNIX epoch (Jan 1, 1970, 0:00:00 UTC).
|
| + * |lastModifiedTime|:
|
| + * Last modified time of the storage from the origin.
|
| + * Number of milliseconds since UNIX epoch.
|
| + *
|
| + * |inUse|, |usedCount|, |lastAccessTime| and |lastModifiedTime| can be
|
| + * missing,
|
| + * and some additional fields can be included.
|
| + * @param {CustomEvent} event PerOriginInfoUpdated event.
|
| */
|
| - var dataArray = event.detail;
|
| -
|
| - for (var i = 0; i < dataArray.length; ++i) {
|
| - var data = dataArray[i];
|
| - var originObject = getOriginObject(data.type, data.host, data.origin);
|
| - copyAttributes_(data, originObject.detail.payload);
|
| - originObject.reveal();
|
| - if (getTreeViewObject().selectedItem == originObject)
|
| - updateDescription();
|
| + function handlePerOriginInfo(event) {
|
| + /**
|
| + * @type {Array<{
|
| + * origin: {!string},
|
| + * type: {!string},
|
| + * host: {!string},
|
| + * inUse: {?boolean},
|
| + * usedCount: {?number},
|
| + * lastAccessTime: {?number}
|
| + * lastModifiedTime: {?number}
|
| + * }>}
|
| + */
|
| + var dataArray = event.detail;
|
| +
|
| + for (var i = 0; i < dataArray.length; ++i) {
|
| + var data = dataArray[i];
|
| + var originObject = getOriginObject(data.type, data.host, data.origin);
|
| + copyAttributes_(data, originObject.detail.payload);
|
| + originObject.reveal();
|
| + if (getTreeViewObject().selectedItem == originObject)
|
| + updateDescription();
|
| + }
|
| }
|
| -}
|
|
|
| -/**
|
| - * Event Handler for |cr.quota.onStatisticsUpdated|.
|
| - * |event.detail| contains misc statistics data as dictionary.
|
| - * @param {CustomEvent} event StatisticsUpdated event.
|
| - */
|
| -function handleStatistics(event) {
|
| /**
|
| - * @type {Object<string>}
|
| + * Event Handler for |cr.quota.onStatisticsUpdated|.
|
| + * |event.detail| contains misc statistics data as dictionary.
|
| + * @param {CustomEvent} event StatisticsUpdated event.
|
| */
|
| - var data = event.detail;
|
| - for (var key in data) {
|
| - var entry = statistics[key];
|
| - if (!entry) {
|
| - entry = cr.doc.createElement('tr');
|
| - $('stat-entries').appendChild(entry);
|
| - statistics[key] = entry;
|
| + function handleStatistics(event) {
|
| + /**
|
| + * @type {Object<string>}
|
| + */
|
| + var data = event.detail;
|
| + for (var key in data) {
|
| + var entry = statistics[key];
|
| + if (!entry) {
|
| + entry = cr.doc.createElement('tr');
|
| + $('stat-entries').appendChild(entry);
|
| + statistics[key] = entry;
|
| + }
|
| + entry.detail = data[key];
|
| + entry.innerHTML = '<td>' + stringToText_(key) + '</td>' +
|
| + '<td>' + stringToText_(entry.detail) + '</td>';
|
| + localize_(entry);
|
| }
|
| - entry.detail = data[key];
|
| - entry.innerHTML =
|
| - '<td>' + stringToText_(key) + '</td>' +
|
| - '<td>' + stringToText_(entry.detail) + '</td>';
|
| - localize_(entry);
|
| }
|
| -}
|
|
|
| -/**
|
| - * Update description on 'tree-item-description' field with
|
| - * selected item in tree view.
|
| - */
|
| -function updateDescription() {
|
| - var item = getTreeViewObject().selectedItem;
|
| - var tbody = $('tree-item-description');
|
| - tbody.innerHTML = '';
|
| -
|
| - if (item) {
|
| - var keyAndLabel = [['type', 'Storage Type'],
|
| - ['host', 'Host Name'],
|
| - ['origin', 'Origin URL'],
|
| - ['usage', 'Total Storage Usage', numBytesToText_],
|
| - ['unlimitedUsage', 'Usage of Unlimited Origins',
|
| - numBytesToText_],
|
| - ['quota', 'Quota', numBytesToText_],
|
| - ['inUse', 'Origin is in use?'],
|
| - ['usedCount', 'Used count'],
|
| - ['lastAccessTime', 'Last Access Time',
|
| - dateToText],
|
| - ['lastModifiedTime', 'Last Modified Time',
|
| - dateToText]
|
| - ];
|
| - for (var i = 0; i < keyAndLabel.length; ++i) {
|
| - var key = keyAndLabel[i][0];
|
| - var label = keyAndLabel[i][1];
|
| - var entry = item.detail.payload[key];
|
| - if (entry === undefined)
|
| - continue;
|
| -
|
| - var normalize = keyAndLabel[i][2] || stringToText_;
|
| -
|
| - var row = cr.doc.createElement('tr');
|
| - row.innerHTML =
|
| - '<td>' + label + '</td>' +
|
| - '<td>' + normalize(entry) + '</td>';
|
| - localize_(row);
|
| - tbody.appendChild(row);
|
| + /**
|
| + * Update description on 'tree-item-description' field with
|
| + * selected item in tree view.
|
| + */
|
| + function updateDescription() {
|
| + var item = getTreeViewObject().selectedItem;
|
| + var tbody = $('tree-item-description');
|
| + tbody.innerHTML = '';
|
| +
|
| + if (item) {
|
| + var keyAndLabel = [
|
| + ['type', 'Storage Type'], ['host', 'Host Name'],
|
| + ['origin', 'Origin URL'],
|
| + ['usage', 'Total Storage Usage', numBytesToText_],
|
| + ['unlimitedUsage', 'Usage of Unlimited Origins', numBytesToText_],
|
| + ['quota', 'Quota', numBytesToText_], ['inUse', 'Origin is in use?'],
|
| + ['usedCount', 'Used count'],
|
| + ['lastAccessTime', 'Last Access Time', dateToText],
|
| + ['lastModifiedTime', 'Last Modified Time', dateToText]
|
| + ];
|
| + for (var i = 0; i < keyAndLabel.length; ++i) {
|
| + var key = keyAndLabel[i][0];
|
| + var label = keyAndLabel[i][1];
|
| + var entry = item.detail.payload[key];
|
| + if (entry === undefined)
|
| + continue;
|
| +
|
| + var normalize = keyAndLabel[i][2] || stringToText_;
|
| +
|
| + var row = cr.doc.createElement('tr');
|
| + row.innerHTML = '<td>' + label + '</td>' +
|
| + '<td>' + normalize(entry) + '</td>';
|
| + localize_(row);
|
| + tbody.appendChild(row);
|
| + }
|
| }
|
| }
|
| -}
|
|
|
| -/**
|
| + /**
|
| * Dump |treeViewObject| or subtree to a object.
|
| * @param {?{cr.ui.Tree|cr.ui.TreeItem}} opt_treeitem
|
| * @return {Object} Dump result object from |treeViewObject|.
|
| */
|
| -function dumpTreeToObj(opt_treeitem) {
|
| - var treeitem = opt_treeitem || getTreeViewObject();
|
| - var res = {};
|
| - res.payload = treeitem.detail.payload;
|
| - res.children = [];
|
| - for (var i in treeitem.detail.children) {
|
| - var child = treeitem.detail.children[i];
|
| - res.children.push(dumpTreeToObj(child));
|
| - }
|
| + function dumpTreeToObj(opt_treeitem) {
|
| + var treeitem = opt_treeitem || getTreeViewObject();
|
| + var res = {};
|
| + res.payload = treeitem.detail.payload;
|
| + res.children = [];
|
| + for (var i in treeitem.detail.children) {
|
| + var child = treeitem.detail.children[i];
|
| + res.children.push(dumpTreeToObj(child));
|
| + }
|
|
|
| - if (isEmptyObject_(res.payload))
|
| - delete res.payload;
|
| + if (isEmptyObject_(res.payload))
|
| + delete res.payload;
|
|
|
| - if (res.children.length == 0)
|
| - delete res.children;
|
| - return res;
|
| -}
|
| + if (res.children.length == 0)
|
| + delete res.children;
|
| + return res;
|
| + }
|
|
|
| -/**
|
| + /**
|
| * Dump |statistics| to a object.
|
| * @return {Object} Dump result object from |statistics|.
|
| */
|
| -function dumpStatisticsToObj() {
|
| - var result = {};
|
| - for (var key in statistics)
|
| - result[key] = statistics[key].detail;
|
| - return result;
|
| -}
|
| -
|
| -/**
|
| - * Event handler for 'dump-button' 'click'ed.
|
| - * Dump and show all data from WebUI page to 'dump-field' element.
|
| - */
|
| -function dump() {
|
| - var separator = '========\n';
|
| -
|
| - $('dump-field').textContent =
|
| - separator +
|
| - 'Summary\n' +
|
| - separator +
|
| - JSON.stringify({availableSpace: availableSpace}, null, 2) + '\n' +
|
| - separator +
|
| - 'Usage And Quota\n' +
|
| - separator +
|
| - JSON.stringify(dumpTreeToObj(), null, 2) + '\n' +
|
| - separator +
|
| - 'Misc Statistics\n' +
|
| - separator +
|
| - JSON.stringify(dumpStatisticsToObj(), null, 2);
|
| -}
|
| -
|
| -function onLoad() {
|
| - cr.ui.decorate('tabbox', cr.ui.TabBox);
|
| -
|
| - cr.quota.onAvailableSpaceUpdated.addEventListener('update',
|
| - handleAvailableSpace);
|
| - cr.quota.onGlobalInfoUpdated.addEventListener('update', handleGlobalInfo);
|
| - cr.quota.onPerHostInfoUpdated.addEventListener('update', handlePerHostInfo);
|
| - cr.quota.onPerOriginInfoUpdated.addEventListener('update',
|
| - handlePerOriginInfo);
|
| - cr.quota.onStatisticsUpdated.addEventListener('update', handleStatistics);
|
| - cr.quota.requestInfo();
|
| -
|
| - $('refresh-button').addEventListener('click', cr.quota.requestInfo, false);
|
| - $('dump-button').addEventListener('click', dump, false);
|
| -}
|
| -
|
| -cr.doc.addEventListener('DOMContentLoaded', onLoad, false);
|
| + function dumpStatisticsToObj() {
|
| + var result = {};
|
| + for (var key in statistics)
|
| + result[key] = statistics[key].detail;
|
| + return result;
|
| + }
|
| +
|
| + /**
|
| + * Event handler for 'dump-button' 'click'ed.
|
| + * Dump and show all data from WebUI page to 'dump-field' element.
|
| + */
|
| + function dump() {
|
| + var separator = '========\n';
|
| +
|
| + $('dump-field').textContent = separator + 'Summary\n' + separator +
|
| + JSON.stringify({availableSpace: availableSpace}, null, 2) + '\n' +
|
| + separator + 'Usage And Quota\n' + separator +
|
| + JSON.stringify(dumpTreeToObj(), null, 2) + '\n' + separator +
|
| + 'Misc Statistics\n' + separator +
|
| + JSON.stringify(dumpStatisticsToObj(), null, 2);
|
| + }
|
| +
|
| + function onLoad() {
|
| + cr.ui.decorate('tabbox', cr.ui.TabBox);
|
| +
|
| + cr.quota.onAvailableSpaceUpdated.addEventListener(
|
| + 'update', handleAvailableSpace);
|
| + cr.quota.onGlobalInfoUpdated.addEventListener('update', handleGlobalInfo);
|
| + cr.quota.onPerHostInfoUpdated.addEventListener('update', handlePerHostInfo);
|
| + cr.quota.onPerOriginInfoUpdated.addEventListener(
|
| + 'update', handlePerOriginInfo);
|
| + cr.quota.onStatisticsUpdated.addEventListener('update', handleStatistics);
|
| + cr.quota.requestInfo();
|
| +
|
| + $('refresh-button').addEventListener('click', cr.quota.requestInfo, false);
|
| + $('dump-button').addEventListener('click', dump, false);
|
| + }
|
| +
|
| + cr.doc.addEventListener('DOMContentLoaded', onLoad, false);
|
| })();
|
|
|