This commit is contained in:
2026-04-07 14:50:23 +09:00
commit b4e485502b
4778 changed files with 2017091 additions and 0 deletions

View File

@@ -0,0 +1,176 @@
<!--
This example requires Tailwind CSS v2.0+
This example requires some changes to your config:
```
// tailwind.config.js
module.exports = {
// ...
plugins: [
// ...
require('@tailwindcss/forms'),
],
}
```
-->
<template>
<div class="m-8">
<form
class="space-y-8 divide-y divide-gray-200"
@submit.prevent="doFilter"
>
<div class="space-y-8 divide-y divide-gray-200 sm:space-y-5">
<div>
<div class="sm:flex sm:items-center">
<div class="sm:flex-auto">
<h1 class="text-xl font-semibold text-gray-900">
필터 테스트
</h1>
<p class="mt-2 text-sm text-gray-700">
입력된 문장을 api를 이용해 검사하고 결과를
표시합니다.
</p>
</div>
<img
v-if="inPregressFlag"
width="32"
src="/loading-load-2.gif"
/>
<div class="mt-4 sm:mt-0 sm:ml-16 sm:flex-none">
<button
type="submit"
class="ml-3 inline-flex justify-center py-2 px-4 border border-transparent shadow-sm text-sm font-medium rounded-md text-white bg-indigo-600 hover:bg-indigo-700 focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-indigo-500"
>
검사하기
</button>
</div>
</div>
<div class="mt-6 sm:mt-5 space-y-6 sm:space-y-5">
<div>
<fieldset class="mt-4">
<legend class="sr-only">Filter Mode</legend>
<div class="space-y-4">
<div
v-for="notificationMethod in notificationMethods"
:key="notificationMethod.id"
class="flex items-center"
>
<input
:id="notificationMethod.id"
v-model="filterMode"
:value="notificationMethod.id"
name="notification-method"
type="radio"
class="focus:ring-indigo-500 h-4 w-4 text-indigo-600 border-gray-300"
/>
<label
:for="notificationMethod.id"
class="ml-3 block text-sm font-medium text-gray-700"
>
{{ notificationMethod.title }}
</label>
</div>
</div>
</fieldset>
</div>
<div
class="sm:grid sm:grid-cols-3 sm:gap-4 sm:items-start sm:border-t sm:border-gray-200 sm:pt-5"
>
<label
for="filterText"
class="block text-sm font-medium text-gray-700 sm:mt-px sm:pt-2"
>
검사할 문장 입력
</label>
<div class="mt-1 sm:mt-0 sm:col-span-2">
<textarea
id="filterText"
v-model="filterText"
name="filterText"
rows="3"
class="max-w-lg shadow-sm block w-full focus:ring-indigo-500 focus:border-indigo-500 sm:text-sm border border-gray-300 rounded-md"
/>
<p class="mt-2 text-sm text-gray-500">
필터 테스트를 위한 문장을 입력하고 아래
검사하기 버튼을 누르세요. <br />
(마지막 실행시간
{{ elispe.toFixed(2) }} 밀리초)
</p>
<pre>{{ resultJson }}</pre>
</div>
</div>
</div>
</div>
</div>
<div class="pt-5">
<div class="flex justify-end"></div>
</div>
</form>
</div>
</template>
<script setup lang="ts">
import { Switch, SwitchGroup, SwitchLabel } from '@headlessui/vue';
definePageMeta({
middleware: 'check-auth-op',
});
const notificationMethods = [
{
id: 'quick',
title: 'mode = quick. 첫번째 매칭이 발견되면 더 이상 검사하지 않고 바로 결과를 리턴',
},
{ id: 'normal', title: 'mode = normal. 전체를 검사하여 모든 매칭을 리턴' },
{
id: 'filter',
title: 'mode = filter. 전체를 검사하며 모든 매칭을 마스크로 치환한 결과까지 리턴',
},
];
const filterText = ref('테스트 할 문장을 이곳에 넣어 주세요.');
const filterMode = ref('filter');
const filterCallback = ref('');
const resultJson = ref({});
const elispe = ref(0);
const inPregressFlag = ref(false);
async function doFilter() {
if (inPregressFlag.value == true) {
alert('이전 동작이 아직 진행중입니다.');
return;
}
inPregressFlag.value = true;
const startTime = performance.now();
const responseJson = await _crossCtl.doFilter('', {
text: filterText.value,
mode: filterMode.value,
});
const endTime = performance.now();
inPregressFlag.value = false;
elispe.value = endTime - startTime;
// console.log('responseJson=', responseJson);
const result = responseJson;
resultJson.value = result;
if (responseJson['Status']['Code'] == 2000) {
// alert(result.length + ' match found');
} else {
alert(responseJson['Status']['Message']);
}
}
</script>