aboutsummaryrefslogtreecommitdiff
path: root/src/tools/text-statistics/text-statistics.vue
blob: 84d4a5265de18d654bb26799b2826f7cbe91e15f (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
<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 === '' ? 0 : text.split(/\s+/).length" />
      <n-statistic label="Line count" :value="text === '' ? 0 : 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 { formatBytes } from '@/utils/convert';
import { ref } from 'vue';
import { getStringSizeInBytes } from './text-statistics.service';

const text = ref('');
</script>