mirror of
https://github.com/CorentinTh/it-tools.git
synced 2025-01-01 05:02:21 +08:00
feat(tool): text statistics
This commit is contained in:
parent
2f49631ff7
commit
0a7c3252e3
7 changed files with 67 additions and 1 deletions
|
@ -44,9 +44,11 @@ import {
|
||||||
NInputGroup,
|
NInputGroup,
|
||||||
NInputGroupLabel,
|
NInputGroupLabel,
|
||||||
NDivider,
|
NDivider,
|
||||||
|
NStatistic,
|
||||||
} from 'naive-ui';
|
} from 'naive-ui';
|
||||||
|
|
||||||
const components = [
|
const components = [
|
||||||
|
NStatistic,
|
||||||
NDivider,
|
NDivider,
|
||||||
NInputGroup,
|
NInputGroup,
|
||||||
NInputGroupLabel,
|
NInputGroupLabel,
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
import { LockOpen } from '@vicons/tabler';
|
import { LockOpen } from '@vicons/tabler';
|
||||||
import type { ToolCategory } from './Tool';
|
import type { ToolCategory } from './Tool';
|
||||||
|
|
||||||
|
import { tool as textStatistics } from './text-statistics';
|
||||||
import { tool as tokenGenerator } from './token-generator';
|
import { tool as tokenGenerator } from './token-generator';
|
||||||
import { tool as hashText } from './hash-text';
|
import { tool as hashText } from './hash-text';
|
||||||
import { tool as uuidGenerator } from './uuid-generator';
|
import { tool as uuidGenerator } from './uuid-generator';
|
||||||
|
@ -38,7 +39,7 @@ export const toolsByCategory: ToolCategory[] = [
|
||||||
{
|
{
|
||||||
name: 'Text',
|
name: 'Text',
|
||||||
icon: LockOpen,
|
icon: LockOpen,
|
||||||
components: [loremIpsumGenerator],
|
components: [loremIpsumGenerator, textStatistics],
|
||||||
},
|
},
|
||||||
];
|
];
|
||||||
|
|
||||||
|
|
11
src/tools/text-statistics/index.ts
Normal file
11
src/tools/text-statistics/index.ts
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
import { FileText } from '@vicons/tabler';
|
||||||
|
import type { ITool } from './../Tool';
|
||||||
|
|
||||||
|
export const tool: ITool = {
|
||||||
|
name: 'Text statistics',
|
||||||
|
path: '/text-statistics',
|
||||||
|
description: "Get information about a text, the amount of characters, the amount of words, it's size, ...",
|
||||||
|
keywords: ['text', 'statistics', 'length', 'characters', 'count', 'size', 'bytes'],
|
||||||
|
component: () => import('./text-statistics.vue'),
|
||||||
|
icon: FileText,
|
||||||
|
};
|
14
src/tools/text-statistics/text-statistics.service.test.ts
Normal file
14
src/tools/text-statistics/text-statistics.service.test.ts
Normal file
|
@ -0,0 +1,14 @@
|
||||||
|
import { expect, describe, it } from 'vitest';
|
||||||
|
import { getStringSizeInBytes } from './text-statistics.service';
|
||||||
|
|
||||||
|
describe('text-statistics', () => {
|
||||||
|
describe('getStringSizeInBytes', () => {
|
||||||
|
it('should return the size of a string in bytes', () => {
|
||||||
|
expect(getStringSizeInBytes('')).toEqual(0);
|
||||||
|
expect(getStringSizeInBytes('a')).toEqual(1);
|
||||||
|
expect(getStringSizeInBytes('aa')).toEqual(2);
|
||||||
|
expect(getStringSizeInBytes('😀')).toEqual(4);
|
||||||
|
expect(getStringSizeInBytes('aaaaaaaaaa')).toEqual(10);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
3
src/tools/text-statistics/text-statistics.service.ts
Normal file
3
src/tools/text-statistics/text-statistics.service.ts
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
export function getStringSizeInBytes(text: string) {
|
||||||
|
return new TextEncoder().encode(text).buffer.byteLength;
|
||||||
|
}
|
24
src/tools/text-statistics/text-statistics.vue
Normal file
24
src/tools/text-statistics/text-statistics.vue
Normal file
|
@ -0,0 +1,24 @@
|
||||||
|
<template>
|
||||||
|
<n-card>
|
||||||
|
<n-input v-model:value="text" type="textarea" placeholder="Your text..." rows="5" />
|
||||||
|
<br>
|
||||||
|
<br>
|
||||||
|
<n-space justify="space-around">
|
||||||
|
<n-statistic label="Character count" :value="text.length" />
|
||||||
|
<n-statistic label="Word count" :value="text.split(/\s+/).length" />
|
||||||
|
<n-statistic label="Line count" :value="text.split(/\r\n|\r|\n/).length" />
|
||||||
|
<n-statistic label="Byte size" :value="formatBytes(getStringSizeInBytes(text))" />
|
||||||
|
</n-space>
|
||||||
|
</n-card>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script setup lang="ts">
|
||||||
|
import { ref } from 'vue'
|
||||||
|
import { formatBytes } from '@/utils/convert'
|
||||||
|
import { getStringSizeInBytes } from './text-statistics.service'
|
||||||
|
|
||||||
|
const text = ref('Lorem ipsum dolor sit amet, consectetur adipiscing elit. Commodo risus faucibus varius volutpat habitasse suspendisse justo inceptos primis mi. Fusce molestie lorem bibendum habitasse litora adipiscing turpis egestas quis nec. Non id conubia vulputate etiam iaculis vitae venenatis hac fusce condimentum. Adipiscing pellentesque venenatis ornare pulvinar tempus hac montes velit erat convallis.')
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style lang="less" scoped>
|
||||||
|
</style>
|
11
src/utils/convert.ts
Normal file
11
src/utils/convert.ts
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
export function formatBytes(bytes: number, decimals = 2) {
|
||||||
|
if (bytes === 0) {
|
||||||
|
return '0 Bytes';
|
||||||
|
}
|
||||||
|
|
||||||
|
const k = 1024;
|
||||||
|
const sizes = ['Bytes', 'KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB'];
|
||||||
|
const i = Math.floor(Math.log(bytes) / Math.log(k));
|
||||||
|
|
||||||
|
return parseFloat((bytes / Math.pow(k, i)).toFixed(decimals)) + ' ' + sizes[i];
|
||||||
|
}
|
Loading…
Reference in a new issue