@internetarchive/collection-browser 0.4.3-alpha.9 → 0.4.4-alpha
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.editorconfig +29 -29
- package/.github/workflows/ci.yml +26 -26
- package/.github/workflows/gh-pages-main.yml +39 -39
- package/.github/workflows/npm-publish.yml +39 -39
- package/.github/workflows/pr-preview.yml +38 -38
- package/.husky/pre-commit +4 -4
- package/LICENSE +661 -661
- package/README.md +83 -83
- package/dist/index.d.ts +9 -9
- package/dist/index.js +9 -9
- package/dist/src/app-root.d.ts +50 -48
- package/dist/src/app-root.js +449 -412
- package/dist/src/app-root.js.map +1 -1
- package/dist/src/assets/img/icons/arrow-left.d.ts +2 -2
- package/dist/src/assets/img/icons/arrow-left.js +2 -2
- package/dist/src/assets/img/icons/arrow-right.d.ts +2 -2
- package/dist/src/assets/img/icons/arrow-right.js +2 -2
- package/dist/src/assets/img/icons/chevron.d.ts +2 -2
- package/dist/src/assets/img/icons/chevron.js +2 -2
- package/dist/src/assets/img/icons/empty-query.d.ts +2 -2
- package/dist/src/assets/img/icons/empty-query.js +2 -2
- package/dist/src/assets/img/icons/eye-closed.d.ts +2 -2
- package/dist/src/assets/img/icons/eye-closed.js +2 -2
- package/dist/src/assets/img/icons/eye.d.ts +2 -2
- package/dist/src/assets/img/icons/eye.js +2 -2
- package/dist/src/assets/img/icons/favorite-filled.d.ts +1 -1
- package/dist/src/assets/img/icons/favorite-filled.js +2 -2
- package/dist/src/assets/img/icons/login-required.d.ts +1 -1
- package/dist/src/assets/img/icons/login-required.js +2 -2
- package/dist/src/assets/img/icons/mediatype/account.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/account.js +2 -2
- package/dist/src/assets/img/icons/mediatype/audio.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/audio.js +2 -2
- package/dist/src/assets/img/icons/mediatype/collection.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/collection.js +2 -2
- package/dist/src/assets/img/icons/mediatype/data.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/data.js +2 -2
- package/dist/src/assets/img/icons/mediatype/etree.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/etree.js +2 -2
- package/dist/src/assets/img/icons/mediatype/film.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/film.js +2 -2
- package/dist/src/assets/img/icons/mediatype/images.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/images.js +2 -2
- package/dist/src/assets/img/icons/mediatype/radio.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/radio.js +2 -2
- package/dist/src/assets/img/icons/mediatype/software.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/software.js +2 -2
- package/dist/src/assets/img/icons/mediatype/texts.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/texts.js +2 -2
- package/dist/src/assets/img/icons/mediatype/tv.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/tv.js +2 -2
- package/dist/src/assets/img/icons/mediatype/video.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/video.js +2 -2
- package/dist/src/assets/img/icons/mediatype/web.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/web.js +2 -2
- package/dist/src/assets/img/icons/null-result.d.ts +2 -2
- package/dist/src/assets/img/icons/null-result.js +2 -2
- package/dist/src/assets/img/icons/restricted.d.ts +1 -1
- package/dist/src/assets/img/icons/restricted.js +2 -2
- package/dist/src/assets/img/icons/reviews.d.ts +1 -1
- package/dist/src/assets/img/icons/reviews.js +2 -2
- package/dist/src/assets/img/icons/upload.d.ts +1 -1
- package/dist/src/assets/img/icons/upload.js +2 -2
- package/dist/src/assets/img/icons/views.d.ts +1 -1
- package/dist/src/assets/img/icons/views.js +2 -2
- package/dist/src/circular-activity-indicator.d.ts +5 -5
- package/dist/src/circular-activity-indicator.js +17 -17
- package/dist/src/collection-browser.d.ts +315 -276
- package/dist/src/collection-browser.js +1276 -1179
- package/dist/src/collection-browser.js.map +1 -1
- package/dist/src/collection-facets/facet-tombstone-row.d.ts +5 -5
- package/dist/src/collection-facets/facet-tombstone-row.js +15 -15
- package/dist/src/collection-facets/facets-template.d.ts +16 -16
- package/dist/src/collection-facets/facets-template.js +125 -125
- package/dist/src/collection-facets/more-facets-content.d.ts +77 -77
- package/dist/src/collection-facets/more-facets-content.js +357 -357
- package/dist/src/collection-facets/more-facets-pagination.d.ts +36 -36
- package/dist/src/collection-facets/more-facets-pagination.js +192 -192
- package/dist/src/collection-facets.d.ts +78 -78
- package/dist/src/collection-facets.js +391 -391
- package/dist/src/empty-placeholder.d.ts +11 -11
- package/dist/src/empty-placeholder.js +42 -42
- package/dist/src/language-code-handler/language-code-handler.d.ts +37 -37
- package/dist/src/language-code-handler/language-code-handler.js +26 -26
- package/dist/src/language-code-handler/language-code-mapping.d.ts +1 -1
- package/dist/src/language-code-handler/language-code-mapping.js +562 -562
- package/dist/src/mediatype/mediatype-config.d.ts +3 -3
- package/dist/src/mediatype/mediatype-config.js +85 -85
- package/dist/src/models.d.ts +114 -112
- package/dist/src/models.js +125 -125
- package/dist/src/models.js.map +1 -1
- package/dist/src/restoration-state-handler.d.ts +45 -45
- package/dist/src/restoration-state-handler.js +230 -230
- package/dist/src/sort-filter-bar/alpha-bar.d.ts +12 -12
- package/dist/src/sort-filter-bar/alpha-bar.js +52 -52
- package/dist/src/sort-filter-bar/img/compact.d.ts +1 -1
- package/dist/src/sort-filter-bar/img/compact.js +2 -2
- package/dist/src/sort-filter-bar/img/list.d.ts +1 -1
- package/dist/src/sort-filter-bar/img/list.js +2 -2
- package/dist/src/sort-filter-bar/img/sort-triangle.d.ts +1 -1
- package/dist/src/sort-filter-bar/img/sort-triangle.js +2 -2
- package/dist/src/sort-filter-bar/img/tile.d.ts +1 -1
- package/dist/src/sort-filter-bar/img/tile.js +2 -2
- package/dist/src/sort-filter-bar/sort-filter-bar.d.ts +108 -108
- package/dist/src/sort-filter-bar/sort-filter-bar.js +428 -428
- package/dist/src/styles/item-image-styles.d.ts +8 -8
- package/dist/src/styles/item-image-styles.js +22 -12
- package/dist/src/styles/item-image-styles.js.map +1 -1
- package/dist/src/tiles/collection-browser-loading-tile.d.ts +5 -5
- package/dist/src/tiles/collection-browser-loading-tile.js +16 -16
- package/dist/src/tiles/collection-browser-loading-tile.js.map +1 -1
- package/dist/src/tiles/grid/account-tile.d.ts +17 -17
- package/dist/src/tiles/grid/account-tile.js +48 -47
- package/dist/src/tiles/grid/account-tile.js.map +1 -1
- package/dist/src/tiles/grid/collection-tile.d.ts +14 -7
- package/dist/src/tiles/grid/collection-tile.js +112 -146
- package/dist/src/tiles/grid/collection-tile.js.map +1 -1
- package/dist/src/tiles/grid/item-tile.d.ts +29 -29
- package/dist/src/tiles/grid/item-tile.js +110 -105
- package/dist/src/tiles/grid/item-tile.js.map +1 -1
- package/dist/src/tiles/grid/styles/tile-grid-shared-styles.d.ts +1 -1
- package/dist/src/tiles/grid/styles/tile-grid-shared-styles.js +12 -8
- package/dist/src/tiles/grid/styles/tile-grid-shared-styles.js.map +1 -1
- package/dist/src/tiles/grid/tile-stats.d.ts +10 -10
- package/dist/src/tiles/grid/tile-stats.js +41 -40
- package/dist/src/tiles/grid/tile-stats.js.map +1 -1
- package/dist/src/tiles/image-block.d.ts +17 -17
- package/dist/src/tiles/image-block.js +76 -72
- package/dist/src/tiles/image-block.js.map +1 -1
- package/dist/src/tiles/item-image.d.ts +35 -35
- package/dist/src/tiles/item-image.js +117 -116
- package/dist/src/tiles/item-image.js.map +1 -1
- package/dist/src/tiles/list/account-label.d.ts +1 -1
- package/dist/src/tiles/list/account-label.js +6 -6
- package/dist/src/tiles/list/date-label.d.ts +1 -1
- package/dist/src/tiles/list/date-label.js +12 -12
- package/dist/src/tiles/list/tile-list-compact-header.d.ts +12 -12
- package/dist/src/tiles/list/tile-list-compact-header.js +41 -41
- package/dist/src/tiles/list/tile-list-compact.d.ts +21 -21
- package/dist/src/tiles/list/tile-list-compact.js +93 -93
- package/dist/src/tiles/list/tile-list.d.ts +53 -53
- package/dist/src/tiles/list/tile-list.js +279 -279
- package/dist/src/tiles/mediatype-icon.d.ts +9 -9
- package/dist/src/tiles/mediatype-icon.js +47 -47
- package/dist/src/tiles/overlay/icon-overlay.d.ts +10 -10
- package/dist/src/tiles/overlay/icon-overlay.js +40 -40
- package/dist/src/tiles/overlay/icon-text-overlay.d.ts +9 -9
- package/dist/src/tiles/overlay/icon-text-overlay.js +38 -38
- package/dist/src/tiles/overlay/text-overlay.d.ts +10 -10
- package/dist/src/tiles/overlay/text-overlay.js +42 -42
- package/dist/src/tiles/text-snippet-block.d.ts +27 -27
- package/dist/src/tiles/text-snippet-block.js +73 -73
- package/dist/src/tiles/tile-dispatcher.d.ts +36 -36
- package/dist/src/tiles/tile-dispatcher.js +145 -128
- package/dist/src/tiles/tile-dispatcher.js.map +1 -1
- package/dist/src/utils/analytics-events.d.ts +22 -22
- package/dist/src/utils/analytics-events.js +24 -24
- package/dist/src/utils/format-count.d.ts +7 -7
- package/dist/src/utils/format-count.js +76 -76
- package/dist/src/utils/format-date.d.ts +2 -2
- package/dist/src/utils/format-date.js +23 -23
- package/dist/src/utils/format-unit-size.d.ts +2 -0
- package/dist/src/utils/format-unit-size.js +34 -0
- package/dist/src/utils/format-unit-size.js.map +1 -0
- package/dist/test/collection-browser.test.d.ts +1 -1
- package/dist/test/collection-browser.test.js +646 -646
- package/dist/test/collection-facets/facets-template.test.d.ts +1 -1
- package/dist/test/collection-facets/facets-template.test.js +62 -62
- package/dist/test/collection-facets/more-facets-content.test.d.ts +1 -1
- package/dist/test/collection-facets/more-facets-content.test.js +114 -114
- package/dist/test/collection-facets/more-facets-pagination.test.d.ts +1 -1
- package/dist/test/collection-facets/more-facets-pagination.test.js +117 -117
- package/dist/test/collection-facets.test.d.ts +2 -2
- package/dist/test/collection-facets.test.js +544 -544
- package/dist/test/empty-placeholder.test.d.ts +1 -1
- package/dist/test/empty-placeholder.test.js +33 -33
- package/dist/test/icon-overlay.test.d.ts +1 -1
- package/dist/test/icon-overlay.test.js +24 -24
- package/dist/test/image-block.test.d.ts +1 -1
- package/dist/test/image-block.test.js +48 -48
- package/dist/test/item-image.test.d.ts +1 -1
- package/dist/test/item-image.test.js +84 -80
- package/dist/test/item-image.test.js.map +1 -1
- package/dist/test/mediatype-config.test.d.ts +1 -1
- package/dist/test/mediatype-config.test.js +16 -16
- package/dist/test/mocks/mock-analytics-handler.d.ts +10 -10
- package/dist/test/mocks/mock-analytics-handler.js +15 -15
- package/dist/test/mocks/mock-collection-name-cache.d.ts +7 -7
- package/dist/test/mocks/mock-collection-name-cache.js +13 -13
- package/dist/test/mocks/mock-search-responses.d.ts +12 -12
- package/dist/test/mocks/mock-search-responses.js +341 -341
- package/dist/test/mocks/mock-search-service.d.ts +13 -13
- package/dist/test/mocks/mock-search-service.js +40 -40
- package/dist/test/restoration-state-handler.test.d.ts +1 -1
- package/dist/test/restoration-state-handler.test.js +125 -125
- package/dist/test/sort-filter-bar/alpha-bar.test.d.ts +1 -1
- package/dist/test/sort-filter-bar/alpha-bar.test.js +43 -43
- package/dist/test/sort-filter-bar/sort-filter-bar.test.d.ts +1 -1
- package/dist/test/sort-filter-bar/sort-filter-bar.test.js +141 -141
- package/dist/test/text-overlay.test.d.ts +1 -1
- package/dist/test/text-overlay.test.js +48 -48
- package/dist/test/text-snippet-block.test.d.ts +1 -1
- package/dist/test/text-snippet-block.test.js +57 -57
- package/dist/test/tile-stats.test.d.ts +1 -1
- package/dist/test/tile-stats.test.js +33 -33
- package/dist/test/tiles/grid/account-tile.test.d.ts +1 -1
- package/dist/test/tiles/grid/account-tile.test.js +60 -60
- package/dist/test/tiles/grid/collection-tile.test.d.ts +1 -0
- package/dist/test/tiles/grid/collection-tile.test.js +73 -0
- package/dist/test/tiles/grid/collection-tile.test.js.map +1 -0
- package/dist/test/tiles/grid/item-tile.test.d.ts +1 -1
- package/dist/test/tiles/grid/item-tile.test.js +142 -129
- package/dist/test/tiles/grid/item-tile.test.js.map +1 -1
- package/dist/test/tiles/list/tile-list-compact.test.d.ts +1 -1
- package/dist/test/tiles/list/tile-list-compact.test.js +92 -92
- package/dist/test/tiles/list/tile-list.test.d.ts +1 -1
- package/dist/test/tiles/list/tile-list.test.js +123 -123
- package/dist/test/utils/format-count.test.d.ts +1 -1
- package/dist/test/utils/format-count.test.js +23 -23
- package/dist/test/utils/format-date.test.d.ts +1 -1
- package/dist/test/utils/format-date.test.js +17 -17
- package/dist/test/utils/format-unit-size.test.d.ts +1 -0
- package/dist/test/utils/format-unit-size.test.js +18 -0
- package/dist/test/utils/format-unit-size.test.js.map +1 -0
- package/index.html +24 -24
- package/local.archive.org.cert +86 -86
- package/local.archive.org.key +27 -27
- package/package.json +2 -2
- package/renovate.json +6 -6
- package/src/app-root.ts +214 -169
- package/src/collection-browser.ts +122 -3
- package/src/models.ts +2 -0
- package/src/styles/item-image-styles.ts +13 -3
- package/src/tiles/collection-browser-loading-tile.ts +1 -1
- package/src/tiles/grid/account-tile.ts +4 -2
- package/src/tiles/grid/collection-tile.ts +106 -136
- package/src/tiles/grid/item-tile.ts +8 -2
- package/src/tiles/grid/styles/tile-grid-shared-styles.ts +6 -2
- package/src/tiles/grid/tile-stats.ts +1 -0
- package/src/tiles/image-block.ts +5 -2
- package/src/tiles/item-image.ts +4 -3
- package/src/tiles/tile-dispatcher.ts +17 -0
- package/src/utils/format-unit-size.ts +43 -0
- package/test/item-image.test.ts +4 -0
- package/test/tiles/grid/collection-tile.test.ts +85 -0
- package/test/tiles/grid/item-tile.test.ts +30 -4
- package/test/utils/format-unit-size.test.ts +21 -0
- package/tsconfig.json +21 -21
- package/web-dev-server.config.mjs +30 -30
- package/web-test-runner.config.mjs +41 -41
|
@@ -1,22 +1,22 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Analytics categories and events. Used when building actions in
|
|
3
|
-
*/
|
|
4
|
-
export declare enum analyticsCategories {
|
|
5
|
-
default = "collection-browser"
|
|
6
|
-
}
|
|
7
|
-
export declare enum analyticsActions {
|
|
8
|
-
sortBy = "sortBy",
|
|
9
|
-
filterByCreator = "filterByCreator",
|
|
10
|
-
filterByTitle = "filterByTitle",
|
|
11
|
-
displayMode = "displayMode",
|
|
12
|
-
facetSelected = "facetSelected",
|
|
13
|
-
facetDeselected = "facetDeselected",
|
|
14
|
-
facetNegativeSelected = "facetNegativeSelected",
|
|
15
|
-
facetNegativeDeselected = "facetNegativeDeselected",
|
|
16
|
-
histogramChanged = "histogramChanged",
|
|
17
|
-
resultSelected = "resultSelected",
|
|
18
|
-
moreFacetsPageChange = "moreFacetsPageChange",
|
|
19
|
-
showMoreFacetsModal = "showMoreFacetsModal",
|
|
20
|
-
closeMoreFacetsModal = "closeMoreFacetsModal",
|
|
21
|
-
applyMoreFacetsModal = "applyMoreFacetsModal"
|
|
22
|
-
}
|
|
1
|
+
/**
|
|
2
|
+
* Analytics categories and events. Used when building actions in
|
|
3
|
+
*/
|
|
4
|
+
export declare enum analyticsCategories {
|
|
5
|
+
default = "collection-browser"
|
|
6
|
+
}
|
|
7
|
+
export declare enum analyticsActions {
|
|
8
|
+
sortBy = "sortBy",
|
|
9
|
+
filterByCreator = "filterByCreator",
|
|
10
|
+
filterByTitle = "filterByTitle",
|
|
11
|
+
displayMode = "displayMode",
|
|
12
|
+
facetSelected = "facetSelected",
|
|
13
|
+
facetDeselected = "facetDeselected",
|
|
14
|
+
facetNegativeSelected = "facetNegativeSelected",
|
|
15
|
+
facetNegativeDeselected = "facetNegativeDeselected",
|
|
16
|
+
histogramChanged = "histogramChanged",
|
|
17
|
+
resultSelected = "resultSelected",
|
|
18
|
+
moreFacetsPageChange = "moreFacetsPageChange",
|
|
19
|
+
showMoreFacetsModal = "showMoreFacetsModal",
|
|
20
|
+
closeMoreFacetsModal = "closeMoreFacetsModal",
|
|
21
|
+
applyMoreFacetsModal = "applyMoreFacetsModal"
|
|
22
|
+
}
|
|
@@ -1,25 +1,25 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Analytics categories and events. Used when building actions in
|
|
3
|
-
*/
|
|
4
|
-
export var analyticsCategories;
|
|
5
|
-
(function (analyticsCategories) {
|
|
6
|
-
analyticsCategories["default"] = "collection-browser";
|
|
7
|
-
})(analyticsCategories || (analyticsCategories = {}));
|
|
8
|
-
export var analyticsActions;
|
|
9
|
-
(function (analyticsActions) {
|
|
10
|
-
analyticsActions["sortBy"] = "sortBy";
|
|
11
|
-
analyticsActions["filterByCreator"] = "filterByCreator";
|
|
12
|
-
analyticsActions["filterByTitle"] = "filterByTitle";
|
|
13
|
-
analyticsActions["displayMode"] = "displayMode";
|
|
14
|
-
analyticsActions["facetSelected"] = "facetSelected";
|
|
15
|
-
analyticsActions["facetDeselected"] = "facetDeselected";
|
|
16
|
-
analyticsActions["facetNegativeSelected"] = "facetNegativeSelected";
|
|
17
|
-
analyticsActions["facetNegativeDeselected"] = "facetNegativeDeselected";
|
|
18
|
-
analyticsActions["histogramChanged"] = "histogramChanged";
|
|
19
|
-
analyticsActions["resultSelected"] = "resultSelected";
|
|
20
|
-
analyticsActions["moreFacetsPageChange"] = "moreFacetsPageChange";
|
|
21
|
-
analyticsActions["showMoreFacetsModal"] = "showMoreFacetsModal";
|
|
22
|
-
analyticsActions["closeMoreFacetsModal"] = "closeMoreFacetsModal";
|
|
23
|
-
analyticsActions["applyMoreFacetsModal"] = "applyMoreFacetsModal";
|
|
24
|
-
})(analyticsActions || (analyticsActions = {}));
|
|
1
|
+
/**
|
|
2
|
+
* Analytics categories and events. Used when building actions in
|
|
3
|
+
*/
|
|
4
|
+
export var analyticsCategories;
|
|
5
|
+
(function (analyticsCategories) {
|
|
6
|
+
analyticsCategories["default"] = "collection-browser";
|
|
7
|
+
})(analyticsCategories || (analyticsCategories = {}));
|
|
8
|
+
export var analyticsActions;
|
|
9
|
+
(function (analyticsActions) {
|
|
10
|
+
analyticsActions["sortBy"] = "sortBy";
|
|
11
|
+
analyticsActions["filterByCreator"] = "filterByCreator";
|
|
12
|
+
analyticsActions["filterByTitle"] = "filterByTitle";
|
|
13
|
+
analyticsActions["displayMode"] = "displayMode";
|
|
14
|
+
analyticsActions["facetSelected"] = "facetSelected";
|
|
15
|
+
analyticsActions["facetDeselected"] = "facetDeselected";
|
|
16
|
+
analyticsActions["facetNegativeSelected"] = "facetNegativeSelected";
|
|
17
|
+
analyticsActions["facetNegativeDeselected"] = "facetNegativeDeselected";
|
|
18
|
+
analyticsActions["histogramChanged"] = "histogramChanged";
|
|
19
|
+
analyticsActions["resultSelected"] = "resultSelected";
|
|
20
|
+
analyticsActions["moreFacetsPageChange"] = "moreFacetsPageChange";
|
|
21
|
+
analyticsActions["showMoreFacetsModal"] = "showMoreFacetsModal";
|
|
22
|
+
analyticsActions["closeMoreFacetsModal"] = "closeMoreFacetsModal";
|
|
23
|
+
analyticsActions["applyMoreFacetsModal"] = "applyMoreFacetsModal";
|
|
24
|
+
})(analyticsActions || (analyticsActions = {}));
|
|
25
25
|
//# sourceMappingURL=analytics-events.js.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
export declare type NumberFormat = 'short' | 'long';
|
|
2
|
-
export declare type LabelFormat = 'short' | 'long';
|
|
3
|
-
/**
|
|
4
|
-
* Format a "count" number into short "icon" or longer text string.
|
|
5
|
-
* For positive numbers only.
|
|
6
|
-
*/
|
|
7
|
-
export declare function formatCount(count: number | undefined, numberFormat?: NumberFormat, labelFormat?: LabelFormat, locale?: string): string;
|
|
1
|
+
export declare type NumberFormat = 'short' | 'long';
|
|
2
|
+
export declare type LabelFormat = 'short' | 'long';
|
|
3
|
+
/**
|
|
4
|
+
* Format a "count" number into short "icon" or longer text string.
|
|
5
|
+
* For positive numbers only.
|
|
6
|
+
*/
|
|
7
|
+
export declare function formatCount(count: number | undefined, numberFormat?: NumberFormat, labelFormat?: LabelFormat, locale?: string): string;
|
|
@@ -1,77 +1,77 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* Replaces Petabox www/common/Util::number_format()
|
|
3
|
-
* For positive numbers only.
|
|
4
|
-
*/
|
|
5
|
-
import { msg, str } from '@lit/localize';
|
|
6
|
-
/**
|
|
7
|
-
* Return the magnitude of a number.
|
|
8
|
-
*/
|
|
9
|
-
function magnitude(number, numberFormat) {
|
|
10
|
-
let divisor = 1;
|
|
11
|
-
if (number >= 1000000000) {
|
|
12
|
-
divisor = 1000000000;
|
|
13
|
-
}
|
|
14
|
-
else if (number >= 1000000) {
|
|
15
|
-
divisor = 1000000;
|
|
16
|
-
}
|
|
17
|
-
else if (number >= 1000 && numberFormat === 'short') {
|
|
18
|
-
divisor = 1000;
|
|
19
|
-
}
|
|
20
|
-
return divisor;
|
|
21
|
-
}
|
|
22
|
-
/**
|
|
23
|
-
* Round a number given passed magnitude.
|
|
24
|
-
* Significant digits of value less than 10 get a decimal.
|
|
25
|
-
*/
|
|
26
|
-
// eslint-disable-next-line default-param-last
|
|
27
|
-
function round(number = 0, divisor) {
|
|
28
|
-
const result = number / divisor;
|
|
29
|
-
const roundToOne = result < 10;
|
|
30
|
-
let rounded = 0;
|
|
31
|
-
if (roundToOne) {
|
|
32
|
-
rounded = Math.round((result + Number.EPSILON) * 10) / 10;
|
|
33
|
-
}
|
|
34
|
-
else {
|
|
35
|
-
rounded = Math.round(result);
|
|
36
|
-
}
|
|
37
|
-
return rounded;
|
|
38
|
-
}
|
|
39
|
-
/**
|
|
40
|
-
* Return a label for a number and format.
|
|
41
|
-
*/
|
|
42
|
-
function labelize(rounded, divisor, format, locale) {
|
|
43
|
-
switch (divisor) {
|
|
44
|
-
case 1000000000:
|
|
45
|
-
if (format === 'short') {
|
|
46
|
-
return msg(str `${rounded}B`);
|
|
47
|
-
}
|
|
48
|
-
return msg(str `${rounded} billion`);
|
|
49
|
-
case 1000000:
|
|
50
|
-
if (format === 'short') {
|
|
51
|
-
return msg(str `${rounded}M`);
|
|
52
|
-
}
|
|
53
|
-
return msg(str `${rounded} million`);
|
|
54
|
-
case 1000:
|
|
55
|
-
if (format === 'short') {
|
|
56
|
-
return msg(str `${rounded}K`);
|
|
57
|
-
}
|
|
58
|
-
return msg(str `${rounded} thousand`);
|
|
59
|
-
default:
|
|
60
|
-
return new Intl.NumberFormat(locale).format(rounded);
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
/**
|
|
64
|
-
* Format a "count" number into short "icon" or longer text string.
|
|
65
|
-
* For positive numbers only.
|
|
66
|
-
*/
|
|
67
|
-
export function formatCount(count, numberFormat = 'long', labelFormat = 'short', locale = 'en-US') {
|
|
68
|
-
// Return blank if undefined
|
|
69
|
-
const number = count !== null && count !== void 0 ? count : -1;
|
|
70
|
-
if (number < 0) {
|
|
71
|
-
return '';
|
|
72
|
-
}
|
|
73
|
-
const divisor = magnitude(number, numberFormat);
|
|
74
|
-
const rounded = round(number, divisor);
|
|
75
|
-
return labelize(rounded, divisor, labelFormat, locale);
|
|
76
|
-
}
|
|
1
|
+
/*
|
|
2
|
+
* Replaces Petabox www/common/Util::number_format()
|
|
3
|
+
* For positive numbers only.
|
|
4
|
+
*/
|
|
5
|
+
import { msg, str } from '@lit/localize';
|
|
6
|
+
/**
|
|
7
|
+
* Return the magnitude of a number.
|
|
8
|
+
*/
|
|
9
|
+
function magnitude(number, numberFormat) {
|
|
10
|
+
let divisor = 1;
|
|
11
|
+
if (number >= 1000000000) {
|
|
12
|
+
divisor = 1000000000;
|
|
13
|
+
}
|
|
14
|
+
else if (number >= 1000000) {
|
|
15
|
+
divisor = 1000000;
|
|
16
|
+
}
|
|
17
|
+
else if (number >= 1000 && numberFormat === 'short') {
|
|
18
|
+
divisor = 1000;
|
|
19
|
+
}
|
|
20
|
+
return divisor;
|
|
21
|
+
}
|
|
22
|
+
/**
|
|
23
|
+
* Round a number given passed magnitude.
|
|
24
|
+
* Significant digits of value less than 10 get a decimal.
|
|
25
|
+
*/
|
|
26
|
+
// eslint-disable-next-line default-param-last
|
|
27
|
+
function round(number = 0, divisor) {
|
|
28
|
+
const result = number / divisor;
|
|
29
|
+
const roundToOne = result < 10;
|
|
30
|
+
let rounded = 0;
|
|
31
|
+
if (roundToOne) {
|
|
32
|
+
rounded = Math.round((result + Number.EPSILON) * 10) / 10;
|
|
33
|
+
}
|
|
34
|
+
else {
|
|
35
|
+
rounded = Math.round(result);
|
|
36
|
+
}
|
|
37
|
+
return rounded;
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* Return a label for a number and format.
|
|
41
|
+
*/
|
|
42
|
+
function labelize(rounded, divisor, format, locale) {
|
|
43
|
+
switch (divisor) {
|
|
44
|
+
case 1000000000:
|
|
45
|
+
if (format === 'short') {
|
|
46
|
+
return msg(str `${rounded}B`);
|
|
47
|
+
}
|
|
48
|
+
return msg(str `${rounded} billion`);
|
|
49
|
+
case 1000000:
|
|
50
|
+
if (format === 'short') {
|
|
51
|
+
return msg(str `${rounded}M`);
|
|
52
|
+
}
|
|
53
|
+
return msg(str `${rounded} million`);
|
|
54
|
+
case 1000:
|
|
55
|
+
if (format === 'short') {
|
|
56
|
+
return msg(str `${rounded}K`);
|
|
57
|
+
}
|
|
58
|
+
return msg(str `${rounded} thousand`);
|
|
59
|
+
default:
|
|
60
|
+
return new Intl.NumberFormat(locale).format(rounded);
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
/**
|
|
64
|
+
* Format a "count" number into short "icon" or longer text string.
|
|
65
|
+
* For positive numbers only.
|
|
66
|
+
*/
|
|
67
|
+
export function formatCount(count, numberFormat = 'long', labelFormat = 'short', locale = 'en-US') {
|
|
68
|
+
// Return blank if undefined
|
|
69
|
+
const number = count !== null && count !== void 0 ? count : -1;
|
|
70
|
+
if (number < 0) {
|
|
71
|
+
return '';
|
|
72
|
+
}
|
|
73
|
+
const divisor = magnitude(number, numberFormat);
|
|
74
|
+
const rounded = round(number, divisor);
|
|
75
|
+
return labelize(rounded, divisor, labelFormat, locale);
|
|
76
|
+
}
|
|
77
77
|
//# sourceMappingURL=format-count.js.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export declare type DateFormat = 'short' | 'long';
|
|
2
|
-
export declare function formatDate(date: Date | undefined, format?: DateFormat, locale?: string): string;
|
|
1
|
+
export declare type DateFormat = 'short' | 'long';
|
|
2
|
+
export declare function formatDate(date: Date | undefined, format?: DateFormat, locale?: string): string;
|
|
@@ -1,24 +1,24 @@
|
|
|
1
|
-
export function formatDate(date, format = 'short', locale = 'en-US') {
|
|
2
|
-
// Return blank if undefined
|
|
3
|
-
if (!date)
|
|
4
|
-
return '';
|
|
5
|
-
const options = {
|
|
6
|
-
timeZone: 'UTC', // Override browser timezone
|
|
7
|
-
};
|
|
8
|
-
switch (format) {
|
|
9
|
-
case 'short':
|
|
10
|
-
options.month = 'short';
|
|
11
|
-
options.year = 'numeric';
|
|
12
|
-
break;
|
|
13
|
-
case 'long':
|
|
14
|
-
options.year = 'numeric';
|
|
15
|
-
options.month = 'short';
|
|
16
|
-
options.day = '2-digit';
|
|
17
|
-
break;
|
|
18
|
-
default:
|
|
19
|
-
break;
|
|
20
|
-
}
|
|
21
|
-
const dateFormatter = new Intl.DateTimeFormat(locale, options);
|
|
22
|
-
return dateFormatter.format(date);
|
|
23
|
-
}
|
|
1
|
+
export function formatDate(date, format = 'short', locale = 'en-US') {
|
|
2
|
+
// Return blank if undefined
|
|
3
|
+
if (!date)
|
|
4
|
+
return '';
|
|
5
|
+
const options = {
|
|
6
|
+
timeZone: 'UTC', // Override browser timezone
|
|
7
|
+
};
|
|
8
|
+
switch (format) {
|
|
9
|
+
case 'short':
|
|
10
|
+
options.month = 'short';
|
|
11
|
+
options.year = 'numeric';
|
|
12
|
+
break;
|
|
13
|
+
case 'long':
|
|
14
|
+
options.year = 'numeric';
|
|
15
|
+
options.month = 'short';
|
|
16
|
+
options.day = '2-digit';
|
|
17
|
+
break;
|
|
18
|
+
default:
|
|
19
|
+
break;
|
|
20
|
+
}
|
|
21
|
+
const dateFormatter = new Intl.DateTimeFormat(locale, options);
|
|
22
|
+
return dateFormatter.format(date);
|
|
23
|
+
}
|
|
24
24
|
//# sourceMappingURL=format-date.js.map
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Replaces Petabox www/common/Util::humanSize()
|
|
3
|
+
*/
|
|
4
|
+
import { nothing } from 'lit';
|
|
5
|
+
var unitSizes;
|
|
6
|
+
(function (unitSizes) {
|
|
7
|
+
unitSizes[unitSizes["bytes"] = 0] = "bytes";
|
|
8
|
+
unitSizes[unitSizes["kilobytes"] = 1] = "kilobytes";
|
|
9
|
+
unitSizes[unitSizes["megabytes"] = 2] = "megabytes";
|
|
10
|
+
unitSizes[unitSizes["gigabytes"] = 3] = "gigabytes";
|
|
11
|
+
unitSizes[unitSizes["terabytes"] = 4] = "terabytes";
|
|
12
|
+
unitSizes[unitSizes["petabytes"] = 5] = "petabytes";
|
|
13
|
+
unitSizes[unitSizes["exabytes"] = 6] = "exabytes";
|
|
14
|
+
unitSizes[unitSizes["zettabytes"] = 7] = "zettabytes";
|
|
15
|
+
unitSizes[unitSizes["yottabytes"] = 8] = "yottabytes";
|
|
16
|
+
})(unitSizes || (unitSizes = {}));
|
|
17
|
+
export function formatUnitSize(size, nDecimals, separator = ' ') {
|
|
18
|
+
let itemSize = size;
|
|
19
|
+
if (itemSize === undefined)
|
|
20
|
+
return nothing; // early return.
|
|
21
|
+
let unitIndex = 0;
|
|
22
|
+
// convert byte to highest possible unit
|
|
23
|
+
while (itemSize > 1024) {
|
|
24
|
+
itemSize /= 1024;
|
|
25
|
+
unitIndex += 1;
|
|
26
|
+
}
|
|
27
|
+
const magnitude = 10 ** nDecimals;
|
|
28
|
+
itemSize = Math.round(itemSize * magnitude) / magnitude;
|
|
29
|
+
let unitText = unitSizes[unitIndex];
|
|
30
|
+
// convert plural to singular.
|
|
31
|
+
unitText = itemSize === 1 ? unitText.slice(0, -1) : unitText;
|
|
32
|
+
return `${itemSize.toLocaleString() + separator + unitText}`;
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=format-unit-size.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"format-unit-size.js","sourceRoot":"","sources":["../../../src/utils/format-unit-size.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,OAAO,EAAE,OAAO,EAAE,MAAM,KAAK,CAAC;AAE9B,IAAK,SAUJ;AAVD,WAAK,SAAS;IACZ,2CAAO,CAAA;IACP,mDAAW,CAAA;IACX,mDAAW,CAAA;IACX,mDAAW,CAAA;IACX,mDAAW,CAAA;IACX,mDAAW,CAAA;IACX,iDAAU,CAAA;IACV,qDAAY,CAAA;IACZ,qDAAY,CAAA;AACd,CAAC,EAVI,SAAS,KAAT,SAAS,QAUb;AAED,MAAM,UAAU,cAAc,CAC5B,IAAwB,EACxB,SAAiB,EACjB,YAAoB,GAAG;IAEvB,IAAI,QAAQ,GAAG,IAAI,CAAC;IACpB,IAAI,QAAQ,KAAK,SAAS;QAAE,OAAO,OAAO,CAAC,CAAC,gBAAgB;IAE5D,IAAI,SAAS,GAAG,CAAC,CAAC;IAElB,wCAAwC;IACxC,OAAO,QAAQ,GAAG,IAAI,EAAE;QACtB,QAAQ,IAAI,IAAI,CAAC;QACjB,SAAS,IAAI,CAAC,CAAC;KAChB;IAED,MAAM,SAAS,GAAG,EAAE,IAAI,SAAS,CAAC;IAClC,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,SAAS,CAAC,GAAG,SAAS,CAAC;IAExD,IAAI,QAAQ,GAAG,SAAS,CAAC,SAAS,CAAC,CAAC;IAEpC,8BAA8B;IAC9B,QAAQ,GAAG,QAAQ,KAAK,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC;IAE7D,OAAO,GAAG,QAAQ,CAAC,cAAc,EAAE,GAAG,SAAS,GAAG,QAAQ,EAAE,CAAC;AAC/D,CAAC","sourcesContent":["/*\n * Replaces Petabox www/common/Util::humanSize()\n */\nimport { nothing } from 'lit';\n\nenum unitSizes {\n 'bytes',\n 'kilobytes',\n 'megabytes',\n 'gigabytes',\n 'terabytes',\n 'petabytes',\n 'exabytes',\n 'zettabytes',\n 'yottabytes',\n}\n\nexport function formatUnitSize(\n size: number | undefined,\n nDecimals: number,\n separator: string = ' '\n) {\n let itemSize = size;\n if (itemSize === undefined) return nothing; // early return.\n\n let unitIndex = 0;\n\n // convert byte to highest possible unit\n while (itemSize > 1024) {\n itemSize /= 1024;\n unitIndex += 1;\n }\n\n const magnitude = 10 ** nDecimals;\n itemSize = Math.round(itemSize * magnitude) / magnitude;\n\n let unitText = unitSizes[unitIndex];\n\n // convert plural to singular.\n unitText = itemSize === 1 ? unitText.slice(0, -1) : unitText;\n\n return `${itemSize.toLocaleString() + separator + unitText}`;\n}\n"]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import '../src/collection-browser';
|
|
1
|
+
import '../src/collection-browser';
|