summaryrefslogtreecommitdiffstats
path: root/core/js
diff options
context:
space:
mode:
authorMorris Jobke <hey@morrisjobke.de>2018-10-25 14:05:20 +0200
committerGitHub <noreply@github.com>2018-10-25 14:05:20 +0200
commit116268a2b594938b9adec2ee65ef4b0391327630 (patch)
tree111ccf1ff0776b4185a15b21fb4281a3ba32a9b7 /core/js
parent49c49d584834f7a5fa21edb5a0a3069c8c14291a (diff)
parentd5e142a33653431eb2f608401e5ae0ba5e532c4c (diff)
downloadnextcloud-server-116268a2b594938b9adec2ee65ef4b0391327630.tar.gz
nextcloud-server-116268a2b594938b9adec2ee65ef4b0391327630.zip
Merge pull request #11893 from caugner/7837-filesize-format-with-locale
Formats file sizes using the user's locale
Diffstat (limited to 'core/js')
-rw-r--r--core/js/js.js13
-rw-r--r--core/js/tests/specs/coreSpec.js58
2 files changed, 71 insertions, 0 deletions
diff --git a/core/js/js.js b/core/js/js.js
index 12c47d546c1..880b986e17b 100644
--- a/core/js/js.js
+++ b/core/js/js.js
@@ -771,6 +771,16 @@ var OCP = {},
},
/**
+ * Returns the user's locale as a BCP 47 compliant language tag
+ *
+ * @return {String} locale string
+ */
+ getCanonicalLocale: function() {
+ var locale = this.getLocale();
+ return typeof locale === 'string' ? locale.replace(/_/g, '-') : locale;
+ },
+
+ /**
* Returns the user's locale
*
* @return {String} locale string
@@ -1843,6 +1853,9 @@ function humanFileSize(size, skipSmallSizes) {
else if(relativeSize.substr(relativeSize.length-2,2)==='.0'){
relativeSize=relativeSize.substr(0,relativeSize.length-2);
}
+ else{
+ relativeSize = parseFloat(relativeSize).toLocaleString(OC.getCanonicalLocale());
+ }
return relativeSize + ' ' + readableFormat;
}
diff --git a/core/js/tests/specs/coreSpec.js b/core/js/tests/specs/coreSpec.js
index 96c8e3f99ec..67b7d77be6c 100644
--- a/core/js/tests/specs/coreSpec.js
+++ b/core/js/tests/specs/coreSpec.js
@@ -273,6 +273,29 @@ describe('Core base tests', function() {
expect(OC.filePath('files', 'ajax', 'test.php')).toEqual('http://localhost/index.php/apps/files/ajax/test.php');
});
});
+ describe('getCanonicalLocale', function() {
+ var localeStub;
+
+ beforeEach(function() {
+ localeStub = sinon.stub(OC, 'getLocale');
+ });
+ afterEach(function() {
+ localeStub.restore();
+ });
+
+ it("Returns primary locales as is", function() {
+ localeStub.returns('de');
+ expect(OC.getCanonicalLocale()).toEqual('de');
+ localeStub.returns('zu');
+ expect(OC.getCanonicalLocale()).toEqual('zu');
+ });
+ it("Returns extended locales with hyphens", function() {
+ localeStub.returns('az_Cyrl_AZ');
+ expect(OC.getCanonicalLocale()).toEqual('az-Cyrl-AZ');
+ localeStub.returns('de_DE');
+ expect(OC.getCanonicalLocale()).toEqual('de-DE');
+ });
+ });
describe('Link functions', function() {
var TESTAPP = 'testapp';
var TESTAPP_ROOT = OC.getRootPath() + '/appsx/testapp';
@@ -560,7 +583,26 @@ describe('Core base tests', function() {
});
});
describe('Util', function() {
+ var locale;
+ var localeStub;
+
+ beforeEach(function() {
+ locale = OC.getCanonicalLocale();
+ localeStub = sinon.stub(OC, 'getCanonicalLocale');
+ localeStub.returns(locale);
+ });
+
+ afterEach(function() {
+ localeStub.restore();
+ });
+
describe('humanFileSize', function() {
+ // cit() will skip tests if toLocaleString() is not supported.
+ // See https://github.com/ariya/phantomjs/issues/12581
+ //
+ // Please run these tests in Chrome/Firefox manually.
+ var cit = 4.2.toLocaleString("de") !== "4,2" ? xit : it;
+
it('renders file sizes with the correct unit', function() {
var data = [
[0, '0 B'],
@@ -589,6 +631,22 @@ describe('Core base tests', function() {
expect(OC.Util.humanFileSize(data[i][0], true)).toEqual(data[i][1]);
}
});
+ cit('renders file sizes with the correct locale', function() {
+ localeStub.returns("de");
+ var data = [
+ [0, '0 B'],
+ ["0", '0 B'],
+ ["A", 'NaN B'],
+ [125, '125 B'],
+ [128000, '125 KB'],
+ [128000000, '122,1 MB'],
+ [128000000000, '119,2 GB'],
+ [128000000000000, '116,4 TB']
+ ];
+ for (var i = 0; i < data.length; i++) {
+ expect(OC.Util.humanFileSize(data[i][0])).toEqual(data[i][1]);
+ }
+ });
});
describe('computerFileSize', function() {
it('correctly parses file sizes from a human readable formated string', function() {