mirror of
https://github.com/hpware/news-analyze.git
synced 2025-06-24 00:01:03 +08:00
Add a basic news view page.
This commit is contained in:
parent
4b7934552c
commit
f34da9f5c1
2
.gitignore
vendored
2
.gitignore
vendored
@ -31,7 +31,7 @@ __pycache__
|
|||||||
.env.sentry-build-plugin
|
.env.sentry-build-plugin
|
||||||
|
|
||||||
*.sql
|
*.sql
|
||||||
!database/*.sql
|
!database/*.sql/
|
||||||
_dt_*.py
|
_dt_*.py
|
||||||
|
|
||||||
# Testing files
|
# Testing files
|
||||||
|
@ -56,7 +56,6 @@ onMounted(async () => {
|
|||||||
} = useFetch(`/api/ai/chat/${chatId.value}`);*/
|
} = useFetch(`/api/ai/chat/${chatId.value}`);*/
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
const sendMessage = async (newMessage: any) => {
|
const sendMessage = async (newMessage: any) => {
|
||||||
if (!newMessage.trim() || !newsId.value.trim() || isStreaming.value) {
|
if (!newMessage.trim() || !newsId.value.trim() || isStreaming.value) {
|
||||||
return;
|
return;
|
||||||
@ -68,7 +67,7 @@ const sendMessage = async (newMessage: any) => {
|
|||||||
user: true,
|
user: true,
|
||||||
timestamp: new Date(),
|
timestamp: new Date(),
|
||||||
});
|
});
|
||||||
messageIndex.value += 1
|
messageIndex.value += 1;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
isStreaming.value = true;
|
isStreaming.value = true;
|
||||||
@ -183,9 +182,7 @@ const formatTime = (timestamp: any) => {
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div v-if="isStreaming" class="">
|
<div v-if="isStreaming" class="">
|
||||||
<div>
|
<div></div>
|
||||||
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="h-[75px]"></div>
|
<div class="h-[75px]"></div>
|
||||||
|
@ -1,5 +1,77 @@
|
|||||||
|
<script setup lang="ts">
|
||||||
|
//const { data: tabs, error: tabserror } = await useFetch("/api/cached/tabs");
|
||||||
|
|
||||||
|
const tabs = [
|
||||||
|
{
|
||||||
|
text: "國內",
|
||||||
|
url: "domestic",
|
||||||
|
default: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
text: "國外",
|
||||||
|
url: "global",
|
||||||
|
default: false,
|
||||||
|
},
|
||||||
|
];
|
||||||
|
|
||||||
|
const primary = ref(tabs.find((tab) => tab.default === true).url || "domestic");
|
||||||
|
const contentArray = ref([]);
|
||||||
|
const errorr = ref(false);
|
||||||
|
|
||||||
|
const updateContent = async (url: string) => {
|
||||||
|
console.log(url.trim());
|
||||||
|
try {
|
||||||
|
const req = await fetch(`/api/home/lt?query=${url.trim()}`);
|
||||||
|
const data = await req.json();
|
||||||
|
console.log(data);
|
||||||
|
if (data) {
|
||||||
|
contentArray.value = [...data.uuidData, ...(data.nuuiddata?.items || [])];
|
||||||
|
}
|
||||||
|
} catch (e) {
|
||||||
|
errorr.value = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return;
|
||||||
|
};
|
||||||
|
|
||||||
|
const isPrimary = (url: string, defaultAction: boolean) => {
|
||||||
|
if (defaultAction === true) {
|
||||||
|
const item = tabs.find((tab) => tab.url === url);
|
||||||
|
if (item.default === true) {
|
||||||
|
return "text-sky-600 text-bold";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (defaultAction === false) {
|
||||||
|
}
|
||||||
|
return "text-black";
|
||||||
|
};
|
||||||
|
onMounted(async () => {
|
||||||
|
await updateContent(primary.value);
|
||||||
|
});
|
||||||
|
</script>
|
||||||
<template>
|
<template>
|
||||||
<div class="justify-center align-center text-center">
|
<div class="justify-center align-center text-center">
|
||||||
<div></div>
|
<!--Tabs-->
|
||||||
|
<div
|
||||||
|
class="sticky inset-x-0 top-0 bg-gray-300/90 backdrop-blur-xl border shadow-lg rounded-xl p-1 m-1 mt-0 justify-center align-center text-center"
|
||||||
|
>
|
||||||
|
<div class="gap-2 flex flex-row justify-center align-center text-center">
|
||||||
|
<button
|
||||||
|
v-for="item in tabs"
|
||||||
|
@click="updateContent(item.url)"
|
||||||
|
:class="isPrimary(item.url, true)"
|
||||||
|
class=""
|
||||||
|
>
|
||||||
|
<span>{{ item.text }}</span>
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div
|
||||||
|
v-for="item in contentArray"
|
||||||
|
:key="item.id"
|
||||||
|
:class="item.contentType !== 'GENERAL' && 'hidden'"
|
||||||
|
>
|
||||||
|
{{ item.title }}
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
@ -15,7 +15,7 @@ const activateAiSummary = ref(false);
|
|||||||
<div class="flex flex-col">
|
<div class="flex flex-col">
|
||||||
<span>AI Summary: </span>
|
<span>AI Summary: </span>
|
||||||
<button v-if="!activateAiSummary">Activate AI summary</button>
|
<button v-if="!activateAiSummary">Activate AI summary</button>
|
||||||
<div v-else>{{ }}</div>
|
<div v-else>{{}}</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
@ -40,16 +40,13 @@ import ChatbotWindow from "~/components/app/windows/chatbot.vue";
|
|||||||
import AboutNewsOrgWindow from "~/components/app/windows/aboutNewsOrg.vue";
|
import AboutNewsOrgWindow from "~/components/app/windows/aboutNewsOrg.vue";
|
||||||
import TTYWindow from "~/components/app/windows/tty.vue";
|
import TTYWindow from "~/components/app/windows/tty.vue";
|
||||||
import FavStaredWindow from "~/components/app/windows/fav.vue";
|
import FavStaredWindow from "~/components/app/windows/fav.vue";
|
||||||
import Error404Window from "~/components/app/windows/error404.vue";
|
|
||||||
import NewsWindow from "~/components/app/windows/news.vue";
|
import NewsWindow from "~/components/app/windows/news.vue";
|
||||||
import NewsViewWindow from "~/components/app/windows/newsView.vue";
|
import NewsViewWindow from "~/components/app/windows/newsView.vue";
|
||||||
import SettingsWindow from "~/components/app/windows/settings.vue"
|
import SettingsWindow from "~/components/app/windows/settings.vue";
|
||||||
|
|
||||||
// Import Icons
|
// Import Icons
|
||||||
import {
|
import {
|
||||||
ComputerDesktopIcon,
|
ComputerDesktopIcon,
|
||||||
UserIcon,
|
|
||||||
LanguageIcon,
|
|
||||||
ChevronRightIcon,
|
ChevronRightIcon,
|
||||||
} from "@heroicons/vue/24/outline";
|
} from "@heroicons/vue/24/outline";
|
||||||
|
|
||||||
@ -230,10 +227,6 @@ const unMinWindow = (windowName?: string) => {
|
|||||||
const toggleMenu = () => {
|
const toggleMenu = () => {
|
||||||
menuOpen.value = !menuOpen.value;
|
menuOpen.value = !menuOpen.value;
|
||||||
};
|
};
|
||||||
// Lang Menu
|
|
||||||
const toggleLangMenu = () => {
|
|
||||||
langMenuOpen.value = !langMenuOpen.value;
|
|
||||||
};
|
|
||||||
|
|
||||||
// ?openapp= component
|
// ?openapp= component
|
||||||
onMounted(async () => {
|
onMounted(async () => {
|
||||||
@ -377,6 +370,7 @@ onMounted(() => {
|
|||||||
}, 2000);
|
}, 2000);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// Loading Effect.
|
||||||
watchEffect((cleanupFn) => {
|
watchEffect((cleanupFn) => {
|
||||||
const tier = setTimeout(() => (progress.value = 10), Math.random() * 50);
|
const tier = setTimeout(() => (progress.value = 10), Math.random() * 50);
|
||||||
const timer = setTimeout(() => (progress.value = 30), Math.random() * 100);
|
const timer = setTimeout(() => (progress.value = 30), Math.random() * 100);
|
||||||
|
@ -46,5 +46,4 @@ export default defineEventHandler(async (event) => {
|
|||||||
},
|
},
|
||||||
});
|
});
|
||||||
return sendStream(event, stream);
|
return sendStream(event, stream);
|
||||||
|
|
||||||
});
|
});
|
||||||
|
3
server/api/cached/tabs.ts
Normal file
3
server/api/cached/tabs.ts
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
export default defineEventHandler(async (event) => {
|
||||||
|
return "cool";
|
||||||
|
});
|
Loading…
x
Reference in New Issue
Block a user