Compare commits
No commits in common. "8566012575240b1ab9e11287369ffd60a97c97b7" and "b3ab1781c328b6cef5aa2bdb36b1d77aec1f7369" have entirely different histories.
8566012575
...
b3ab1781c3
@ -6,23 +6,23 @@
|
|||||||
<div class="title-section">
|
<div class="title-section">
|
||||||
<div class="title-decoration"></div>
|
<div class="title-decoration"></div>
|
||||||
<div class="stock-title">
|
<div class="stock-title">
|
||||||
<span>{{ t("historic_stock.echarts.title") }}</span>
|
<span>FiEE, Inc. Stock Price History</span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="echarts-search-area">
|
<div class="echarts-search-area">
|
||||||
<div class="echarts-search-byRange">
|
<div class="echarts-search-byRange">
|
||||||
<text style="font-size: 0.9rem; font-weight: 400; color: #666666">
|
<text style="font-size: 0.9rem; font-weight: 400; color: #666666">
|
||||||
{{ t("historic_stock.echarts.range") }}
|
Range
|
||||||
</text>
|
</text>
|
||||||
<div class="search-range-list">
|
<div class="search-range-list">
|
||||||
<div
|
<div
|
||||||
class="search-range-list-each"
|
class="search-range-list-each"
|
||||||
v-for="(item, index) in searchRangeOptions"
|
v-for="(item, index) in state.searchRange"
|
||||||
:key="index"
|
:key="index"
|
||||||
:class="{ activeRange: state.activeRange === item.key }"
|
:class="{ activeRange: state.activeRange === item }"
|
||||||
@click="changeSearchRange(item.key)"
|
@click="changeSearchRange(item)"
|
||||||
>
|
>
|
||||||
<span>{{ item.label }}</span>
|
<span>{{ item }}</span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -42,30 +42,17 @@
|
|||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
<script setup>
|
<script setup>
|
||||||
import { onMounted, onBeforeUnmount, watch, reactive, computed } from "vue";
|
import { onMounted, watch, reactive } from "vue";
|
||||||
import { useI18n } from "vue-i18n";
|
|
||||||
import * as echarts from "echarts";
|
import * as echarts from "echarts";
|
||||||
import { NDatePicker, NIcon } from "naive-ui";
|
import { NDatePicker, NIcon } from "naive-ui";
|
||||||
import { ArrowForwardOutline } from "@vicons/ionicons5";
|
import { ArrowForwardOutline } from "@vicons/ionicons5";
|
||||||
import axios from "axios";
|
import axios from "axios";
|
||||||
|
|
||||||
const { t, locale } = useI18n();
|
|
||||||
const state = reactive({
|
const state = reactive({
|
||||||
searchRange: ["1m", "3m", "YTD", "1Y", "5Y", "10Y", "Max"],
|
searchRange: ["1m", "3m", "YTD", "1Y", "5Y", "10Y", "Max"],
|
||||||
dateRange: [new Date("2009-10-07").getTime(), new Date().getTime()],
|
dateRange: [new Date("2009-10-07").getTime(), new Date().getTime()],
|
||||||
activeRange: "",
|
activeRange: "",
|
||||||
});
|
});
|
||||||
|
|
||||||
const searchRangeOptions = computed(() => [
|
|
||||||
{ label: t("historic_stock.echarts.1m"), key: "1m" },
|
|
||||||
{ label: t("historic_stock.echarts.3m"), key: "3m" },
|
|
||||||
{ label: t("historic_stock.echarts.ytd_short"), key: "YTD" },
|
|
||||||
{ label: t("historic_stock.echarts.1y"), key: "1Y" },
|
|
||||||
{ label: t("historic_stock.echarts.5y"), key: "5Y" },
|
|
||||||
{ label: t("historic_stock.echarts.10y"), key: "10Y" },
|
|
||||||
{ label: t("historic_stock.echarts.max"), key: "Max" },
|
|
||||||
]);
|
|
||||||
|
|
||||||
let myCharts = null;
|
let myCharts = null;
|
||||||
let historicData = [];
|
let historicData = [];
|
||||||
let xAxisData = [];
|
let xAxisData = [];
|
||||||
@ -109,11 +96,7 @@ const initEcharts = (data) => {
|
|||||||
},
|
},
|
||||||
formatter: function (params) {
|
formatter: function (params) {
|
||||||
const p = params[0];
|
const p = params[0];
|
||||||
return `<span style="font-size: 1.1rem; font-weight: 600;">${
|
return `<span style="font-size: 1.1rem; font-weight: 600;">${p.axisValue}</span><br/><span style="font-size: 0.9rem; font-weight: 400;">Price: ${p.data}</span>`;
|
||||||
p.axisValue
|
|
||||||
}</span><br/><span style="font-size: 0.9rem; font-weight: 400;">${t(
|
|
||||||
"historic_stock.echarts.price"
|
|
||||||
)}: ${p.data}</span>`;
|
|
||||||
},
|
},
|
||||||
triggerOn: "mousemove",
|
triggerOn: "mousemove",
|
||||||
confine: true,
|
confine: true,
|
||||||
@ -310,44 +293,8 @@ const initEcharts = (data) => {
|
|||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
// 防抖函数
|
|
||||||
const debounce = (func, wait) => {
|
|
||||||
let timeout;
|
|
||||||
return function executedFunction(...args) {
|
|
||||||
const later = () => {
|
|
||||||
clearTimeout(timeout);
|
|
||||||
func(...args);
|
|
||||||
};
|
|
||||||
clearTimeout(timeout);
|
|
||||||
timeout = setTimeout(later, wait);
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
// 处理窗口大小变化
|
|
||||||
const handleResize = () => {
|
|
||||||
if (myCharts) {
|
|
||||||
myCharts.resize();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
// 创建防抖后的 resize 处理函数
|
|
||||||
const debouncedResize = debounce(handleResize, 300);
|
|
||||||
|
|
||||||
onMounted(() => {
|
onMounted(() => {
|
||||||
getHistoricalData();
|
getHistoricalData();
|
||||||
// 添加窗口 resize 监听
|
|
||||||
window.addEventListener("resize", debouncedResize);
|
|
||||||
});
|
|
||||||
|
|
||||||
// 组件卸载时清理
|
|
||||||
onBeforeUnmount(() => {
|
|
||||||
// 移除 resize 监听
|
|
||||||
window.removeEventListener("resize", debouncedResize);
|
|
||||||
// 销毁 echarts 实例
|
|
||||||
if (myCharts) {
|
|
||||||
myCharts.dispose();
|
|
||||||
myCharts = null;
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
|
|
||||||
//获取历史数据
|
//获取历史数据
|
||||||
@ -629,7 +576,6 @@ const handleDateRangeChange = (range) => {
|
|||||||
flex-direction: row;
|
flex-direction: row;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
justify-content: space-between;
|
justify-content: space-between;
|
||||||
flex-wrap: wrap;
|
|
||||||
gap: 10px;
|
gap: 10px;
|
||||||
|
|
||||||
.echarts-search-byRange {
|
.echarts-search-byRange {
|
||||||
|
@ -42,7 +42,7 @@
|
|||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
<script setup>
|
<script setup>
|
||||||
import { onMounted, onBeforeUnmount, watch, reactive, computed } from "vue";
|
import { onMounted, watch, reactive, computed } from "vue";
|
||||||
import * as echarts from "echarts";
|
import * as echarts from "echarts";
|
||||||
import { NDatePicker, NIcon } from "naive-ui";
|
import { NDatePicker, NIcon } from "naive-ui";
|
||||||
import { ArrowForwardOutline } from "@vicons/ionicons5";
|
import { ArrowForwardOutline } from "@vicons/ionicons5";
|
||||||
@ -309,44 +309,8 @@ const initEcharts = (data) => {
|
|||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
// 防抖函数
|
|
||||||
const debounce = (func, wait) => {
|
|
||||||
let timeout;
|
|
||||||
return function executedFunction(...args) {
|
|
||||||
const later = () => {
|
|
||||||
clearTimeout(timeout);
|
|
||||||
func(...args);
|
|
||||||
};
|
|
||||||
clearTimeout(timeout);
|
|
||||||
timeout = setTimeout(later, wait);
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
// 处理窗口大小变化
|
|
||||||
const handleResize = () => {
|
|
||||||
if (myCharts) {
|
|
||||||
myCharts.resize();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
// 创建防抖后的 resize 处理函数
|
|
||||||
const debouncedResize = debounce(handleResize, 300);
|
|
||||||
|
|
||||||
onMounted(() => {
|
onMounted(() => {
|
||||||
getHistoricalData();
|
getHistoricalData();
|
||||||
// 添加窗口 resize 监听
|
|
||||||
window.addEventListener("resize", debouncedResize);
|
|
||||||
});
|
|
||||||
|
|
||||||
// 组件卸载时清理
|
|
||||||
onBeforeUnmount(() => {
|
|
||||||
// 移除 resize 监听
|
|
||||||
window.removeEventListener("resize", debouncedResize);
|
|
||||||
// 销毁 echarts 实例
|
|
||||||
if (myCharts) {
|
|
||||||
myCharts.dispose();
|
|
||||||
myCharts = null;
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
|
|
||||||
//获取历史数据
|
//获取历史数据
|
||||||
@ -628,8 +592,6 @@ const handleDateRangeChange = (range) => {
|
|||||||
flex-direction: row;
|
flex-direction: row;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
justify-content: space-between;
|
justify-content: space-between;
|
||||||
flex-wrap: wrap;
|
|
||||||
gap: 10px;
|
|
||||||
|
|
||||||
.echarts-search-byRange {
|
.echarts-search-byRange {
|
||||||
display: flex;
|
display: flex;
|
||||||
|
@ -6,31 +6,27 @@
|
|||||||
<div class="title-section">
|
<div class="title-section">
|
||||||
<div class="title-decoration"></div>
|
<div class="title-decoration"></div>
|
||||||
<div class="title-text">
|
<div class="title-text">
|
||||||
<span>{{ t("historic_stock.echarts.title") }}</span>
|
<span>FiEE, Inc. Stock Price History</span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="echarts-search-area">
|
<div class="echarts-search-area">
|
||||||
<div class="echarts-search-byRange">
|
<div class="echarts-search-byRange">
|
||||||
<span class="range-label">{{
|
<span class="range-label">Range</span>
|
||||||
t("historic_stock.echarts.range")
|
|
||||||
}}</span>
|
|
||||||
<div class="search-range-list">
|
<div class="search-range-list">
|
||||||
<div
|
<div
|
||||||
class="search-range-list-each"
|
class="search-range-list-each"
|
||||||
v-for="(item, index) in searchRangeOptions"
|
v-for="(item, index) in state.searchRange"
|
||||||
:key="index"
|
:key="index"
|
||||||
:class="{ activeRange: state.activeRange === item.key }"
|
:class="{ activeRange: state.activeRange === item }"
|
||||||
@click="changeSearchRange(item.key)"
|
@click="changeSearchRange(item)"
|
||||||
>
|
>
|
||||||
<span>{{ item.label }}</span>
|
<span>{{ item }}</span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="echarts-search-byDate">
|
<div class="echarts-search-byDate">
|
||||||
<div class="date-row" @click="openPicker('start')">
|
<div class="date-row" @click="openPicker('start')">
|
||||||
<span class="date-label">{{
|
<span class="date-label">Start Time</span>
|
||||||
t("historic_stock.echarts.start_time")
|
|
||||||
}}</span>
|
|
||||||
<div class="date-value">
|
<div class="date-value">
|
||||||
<span>{{ formatYMD(state.dateRange[0]) }}</span>
|
<span>{{ formatYMD(state.dateRange[0]) }}</span>
|
||||||
<svg
|
<svg
|
||||||
@ -50,9 +46,7 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="date-row" @click="openPicker('end')">
|
<div class="date-row" @click="openPicker('end')">
|
||||||
<span class="date-label">{{
|
<span class="date-label">End Time</span>
|
||||||
t("historic_stock.echarts.end_time")
|
|
||||||
}}</span>
|
|
||||||
<div class="date-value">
|
<div class="date-value">
|
||||||
<span>{{ formatYMD(state.dateRange[1]) }}</span>
|
<span>{{ formatYMD(state.dateRange[1]) }}</span>
|
||||||
<svg
|
<svg
|
||||||
@ -98,15 +92,12 @@
|
|||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
<script setup>
|
<script setup>
|
||||||
import { onMounted, onBeforeUnmount, watch, reactive, computed } from "vue";
|
import { onMounted, watch, reactive } from "vue";
|
||||||
import { useI18n } from "vue-i18n";
|
|
||||||
import * as echarts from "echarts";
|
import * as echarts from "echarts";
|
||||||
import { NDatePicker, NIcon } from "naive-ui";
|
import { NDatePicker, NIcon } from "naive-ui";
|
||||||
import { ArrowForwardOutline } from "@vicons/ionicons5";
|
import { ArrowForwardOutline } from "@vicons/ionicons5";
|
||||||
import axios from "axios";
|
import axios from "axios";
|
||||||
import DateWheelPicker from "../../DateWheelPicker.vue";
|
import DateWheelPicker from "../../DateWheelPicker.vue";
|
||||||
|
|
||||||
const { t, locale } = useI18n();
|
|
||||||
const state = reactive({
|
const state = reactive({
|
||||||
searchRange: ["1m", "3m", "YTD", "1Y", "5Y", "10Y", "Max"],
|
searchRange: ["1m", "3m", "YTD", "1Y", "5Y", "10Y", "Max"],
|
||||||
dateRange: [new Date("2009-10-07").getTime(), new Date().getTime()],
|
dateRange: [new Date("2009-10-07").getTime(), new Date().getTime()],
|
||||||
@ -118,16 +109,6 @@ const state = reactive({
|
|||||||
pickerDay: new Date().getDate(),
|
pickerDay: new Date().getDate(),
|
||||||
});
|
});
|
||||||
|
|
||||||
const searchRangeOptions = computed(() => [
|
|
||||||
{ label: t("historic_stock.echarts.1m"), key: "1m" },
|
|
||||||
{ label: t("historic_stock.echarts.3m"), key: "3m" },
|
|
||||||
{ label: t("historic_stock.echarts.ytd_short"), key: "YTD" },
|
|
||||||
{ label: t("historic_stock.echarts.1y"), key: "1Y" },
|
|
||||||
{ label: t("historic_stock.echarts.5y"), key: "5Y" },
|
|
||||||
{ label: t("historic_stock.echarts.10y"), key: "10Y" },
|
|
||||||
{ label: t("historic_stock.echarts.max"), key: "Max" },
|
|
||||||
]);
|
|
||||||
|
|
||||||
// 已封装为子组件,不再需要本地列配置
|
// 已封装为子组件,不再需要本地列配置
|
||||||
|
|
||||||
let myCharts = null;
|
let myCharts = null;
|
||||||
@ -173,11 +154,7 @@ const initEcharts = (data) => {
|
|||||||
},
|
},
|
||||||
formatter: function (params) {
|
formatter: function (params) {
|
||||||
const p = params[0];
|
const p = params[0];
|
||||||
return `<span style="font-size: 1.1rem; font-weight: 600;">${
|
return `<span style="font-size: 1.1rem; font-weight: 600;">${p.axisValue}</span><br/><span style="font-size: 0.9rem; font-weight: 400;">Price: ${p.data}</span>`;
|
||||||
p.axisValue
|
|
||||||
}</span><br/><span style="font-size: 0.9rem; font-weight: 400;">${t(
|
|
||||||
"historic_stock.echarts.price"
|
|
||||||
)}: ${p.data}</span>`;
|
|
||||||
},
|
},
|
||||||
triggerOn: "mousemove",
|
triggerOn: "mousemove",
|
||||||
confine: true,
|
confine: true,
|
||||||
@ -374,44 +351,8 @@ const initEcharts = (data) => {
|
|||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
// 防抖函数
|
|
||||||
const debounce = (func, wait) => {
|
|
||||||
let timeout;
|
|
||||||
return function executedFunction(...args) {
|
|
||||||
const later = () => {
|
|
||||||
clearTimeout(timeout);
|
|
||||||
func(...args);
|
|
||||||
};
|
|
||||||
clearTimeout(timeout);
|
|
||||||
timeout = setTimeout(later, wait);
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
// 处理窗口大小变化
|
|
||||||
const handleResize = () => {
|
|
||||||
if (myCharts) {
|
|
||||||
myCharts.resize();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
// 创建防抖后的 resize 处理函数
|
|
||||||
const debouncedResize = debounce(handleResize, 300);
|
|
||||||
|
|
||||||
onMounted(() => {
|
onMounted(() => {
|
||||||
getHistoricalData();
|
getHistoricalData();
|
||||||
// 添加窗口 resize 监听
|
|
||||||
window.addEventListener("resize", debouncedResize);
|
|
||||||
});
|
|
||||||
|
|
||||||
// 组件卸载时清理
|
|
||||||
onBeforeUnmount(() => {
|
|
||||||
// 移除 resize 监听
|
|
||||||
window.removeEventListener("resize", debouncedResize);
|
|
||||||
// 销毁 echarts 实例
|
|
||||||
if (myCharts) {
|
|
||||||
myCharts.dispose();
|
|
||||||
myCharts = null;
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
|
|
||||||
//获取历史数据
|
//获取历史数据
|
||||||
@ -765,7 +706,6 @@ watch(
|
|||||||
flex-direction: column;
|
flex-direction: column;
|
||||||
justify-content: center;
|
justify-content: center;
|
||||||
gap: 10 * 5.12px;
|
gap: 10 * 5.12px;
|
||||||
flex-wrap: wrap;
|
|
||||||
|
|
||||||
.echarts-search-byRange {
|
.echarts-search-byRange {
|
||||||
width: 100%;
|
width: 100%;
|
||||||
|
@ -6,23 +6,23 @@
|
|||||||
<div class="title-section">
|
<div class="title-section">
|
||||||
<div class="title-decoration"></div>
|
<div class="title-decoration"></div>
|
||||||
<div class="title-text">
|
<div class="title-text">
|
||||||
<span>{{ t("historic_stock.echarts.title") }}</span>
|
<span>FiEE, Inc. Stock Price History</span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="echarts-search-area">
|
<div class="echarts-search-area">
|
||||||
<div class="echarts-search-byRange">
|
<div class="echarts-search-byRange">
|
||||||
<text style="font-size: 0.9rem; font-weight: 400; color: #666666">
|
<text style="font-size: 0.9rem; font-weight: 400; color: #666666">
|
||||||
{{ t("historic_stock.echarts.range") }}
|
Range
|
||||||
</text>
|
</text>
|
||||||
<div class="search-range-list">
|
<div class="search-range-list">
|
||||||
<div
|
<div
|
||||||
class="search-range-list-each"
|
class="search-range-list-each"
|
||||||
v-for="(item, index) in searchRangeOptions"
|
v-for="(item, index) in state.searchRange"
|
||||||
:key="index"
|
:key="index"
|
||||||
:class="{ activeRange: state.activeRange === item.key }"
|
:class="{ activeRange: state.activeRange === item }"
|
||||||
@click="changeSearchRange(item.key)"
|
@click="changeSearchRange(item)"
|
||||||
>
|
>
|
||||||
<span>{{ item.label }}</span>
|
<span>{{ item }}</span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -42,30 +42,17 @@
|
|||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
<script setup>
|
<script setup>
|
||||||
import { onMounted, onBeforeUnmount, watch, reactive, computed } from "vue";
|
import { onMounted, watch, reactive } from "vue";
|
||||||
import { useI18n } from "vue-i18n";
|
|
||||||
import * as echarts from "echarts";
|
import * as echarts from "echarts";
|
||||||
import { NDatePicker, NIcon } from "naive-ui";
|
import { NDatePicker, NIcon } from "naive-ui";
|
||||||
import { ArrowForwardOutline } from "@vicons/ionicons5";
|
import { ArrowForwardOutline } from "@vicons/ionicons5";
|
||||||
import axios from "axios";
|
import axios from "axios";
|
||||||
|
|
||||||
const { t, locale } = useI18n();
|
|
||||||
const state = reactive({
|
const state = reactive({
|
||||||
searchRange: ["1m", "3m", "YTD", "1Y", "5Y", "10Y", "Max"],
|
searchRange: ["1m", "3m", "YTD", "1Y", "5Y", "10Y", "Max"],
|
||||||
dateRange: [new Date("2009-10-07").getTime(), new Date().getTime()],
|
dateRange: [new Date("2009-10-07").getTime(), new Date().getTime()],
|
||||||
activeRange: "",
|
activeRange: "",
|
||||||
});
|
});
|
||||||
|
|
||||||
const searchRangeOptions = computed(() => [
|
|
||||||
{ label: t("historic_stock.echarts.1m"), key: "1m" },
|
|
||||||
{ label: t("historic_stock.echarts.3m"), key: "3m" },
|
|
||||||
{ label: t("historic_stock.echarts.ytd_short"), key: "YTD" },
|
|
||||||
{ label: t("historic_stock.echarts.1y"), key: "1Y" },
|
|
||||||
{ label: t("historic_stock.echarts.5y"), key: "5Y" },
|
|
||||||
{ label: t("historic_stock.echarts.10y"), key: "10Y" },
|
|
||||||
{ label: t("historic_stock.echarts.max"), key: "Max" },
|
|
||||||
]);
|
|
||||||
|
|
||||||
let myCharts = null;
|
let myCharts = null;
|
||||||
let historicData = [];
|
let historicData = [];
|
||||||
let xAxisData = [];
|
let xAxisData = [];
|
||||||
@ -109,11 +96,7 @@ const initEcharts = (data) => {
|
|||||||
},
|
},
|
||||||
formatter: function (params) {
|
formatter: function (params) {
|
||||||
const p = params[0];
|
const p = params[0];
|
||||||
return `<span style="font-size: 1.1rem; font-weight: 600;">${
|
return `<span style="font-size: 1.1rem; font-weight: 600;">${p.axisValue}</span><br/><span style="font-size: 0.9rem; font-weight: 400;">Price: ${p.data}</span>`;
|
||||||
p.axisValue
|
|
||||||
}</span><br/><span style="font-size: 0.9rem; font-weight: 400;">${t(
|
|
||||||
"historic_stock.echarts.price"
|
|
||||||
)}: ${p.data}</span>`;
|
|
||||||
},
|
},
|
||||||
triggerOn: "mousemove",
|
triggerOn: "mousemove",
|
||||||
confine: true,
|
confine: true,
|
||||||
@ -310,44 +293,8 @@ const initEcharts = (data) => {
|
|||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
// 防抖函数
|
|
||||||
const debounce = (func, wait) => {
|
|
||||||
let timeout;
|
|
||||||
return function executedFunction(...args) {
|
|
||||||
const later = () => {
|
|
||||||
clearTimeout(timeout);
|
|
||||||
func(...args);
|
|
||||||
};
|
|
||||||
clearTimeout(timeout);
|
|
||||||
timeout = setTimeout(later, wait);
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
// 处理窗口大小变化
|
|
||||||
const handleResize = () => {
|
|
||||||
if (myCharts) {
|
|
||||||
myCharts.resize();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
// 创建防抖后的 resize 处理函数
|
|
||||||
const debouncedResize = debounce(handleResize, 300);
|
|
||||||
|
|
||||||
onMounted(() => {
|
onMounted(() => {
|
||||||
getHistoricalData();
|
getHistoricalData();
|
||||||
// 添加窗口 resize 监听
|
|
||||||
window.addEventListener("resize", debouncedResize);
|
|
||||||
});
|
|
||||||
|
|
||||||
// 组件卸载时清理
|
|
||||||
onBeforeUnmount(() => {
|
|
||||||
// 移除 resize 监听
|
|
||||||
window.removeEventListener("resize", debouncedResize);
|
|
||||||
// 销毁 echarts 实例
|
|
||||||
if (myCharts) {
|
|
||||||
myCharts.dispose();
|
|
||||||
myCharts = null;
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
|
|
||||||
//获取历史数据
|
//获取历史数据
|
||||||
@ -631,7 +578,6 @@ const handleDateRangeChange = (range) => {
|
|||||||
flex-direction: column;
|
flex-direction: column;
|
||||||
justify-content: center;
|
justify-content: center;
|
||||||
gap: 10 * 2.5px;
|
gap: 10 * 2.5px;
|
||||||
flex-wrap: wrap;
|
|
||||||
|
|
||||||
.echarts-search-byRange {
|
.echarts-search-byRange {
|
||||||
width: 100%;
|
width: 100%;
|
||||||
@ -646,7 +592,6 @@ const handleDateRangeChange = (range) => {
|
|||||||
align-items: center;
|
align-items: center;
|
||||||
justify-content: flex-start;
|
justify-content: flex-start;
|
||||||
gap: 16 * 2.5px;
|
gap: 16 * 2.5px;
|
||||||
flex-wrap: wrap;
|
|
||||||
.search-range-list-each {
|
.search-range-list-each {
|
||||||
padding: 7 * 2.5px 22 * 2.5px;
|
padding: 7 * 2.5px 22 * 2.5px;
|
||||||
border-radius: 5px;
|
border-radius: 5px;
|
||||||
|
@ -17,9 +17,9 @@ const viewComponent = computed(() => {
|
|||||||
const viewWidth = width.value;
|
const viewWidth = width.value;
|
||||||
if (viewWidth <= 450) {
|
if (viewWidth <= 450) {
|
||||||
return size375;
|
return size375;
|
||||||
} else if (viewWidth <= 1100) {
|
} else if (viewWidth <= 835) {
|
||||||
return size768;
|
return size768;
|
||||||
} else if (viewWidth <= 1500) {
|
} else if (viewWidth <= 1640) {
|
||||||
return size1440;
|
return size1440;
|
||||||
} else if (viewWidth <= 1920 || viewWidth > 1920) {
|
} else if (viewWidth <= 1920 || viewWidth > 1920) {
|
||||||
return size1920;
|
return size1920;
|
||||||
|
@ -1,48 +0,0 @@
|
|||||||
<script setup>
|
|
||||||
import { computed } from "vue";
|
|
||||||
import { useWindowSize } from "@vueuse/core";
|
|
||||||
|
|
||||||
import size375 from "@/components/customSelect/size375/index.vue";
|
|
||||||
import size768 from "@/components/customSelect/size768/index.vue";
|
|
||||||
import size1440 from "@/components/customSelect/size1440/index.vue";
|
|
||||||
import size1920 from "@/components/customSelect/size1920/index.vue";
|
|
||||||
|
|
||||||
const props = defineProps({
|
|
||||||
options: {
|
|
||||||
type: Array,
|
|
||||||
required: true,
|
|
||||||
},
|
|
||||||
modelValue: {
|
|
||||||
type: [String, Number],
|
|
||||||
required: true,
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
const emit = defineEmits(["update:modelValue"]);
|
|
||||||
|
|
||||||
const { width } = useWindowSize();
|
|
||||||
|
|
||||||
const viewComponent = computed(() => {
|
|
||||||
const viewWidth = width.value;
|
|
||||||
if (viewWidth <= 450) {
|
|
||||||
return size375;
|
|
||||||
} else if (viewWidth <= 1100) {
|
|
||||||
return size768;
|
|
||||||
} else if (viewWidth <= 1500) {
|
|
||||||
return size1440;
|
|
||||||
} else if (viewWidth <= 1920 || viewWidth > 1920) {
|
|
||||||
return size1920;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<template>
|
|
||||||
<component
|
|
||||||
:is="viewComponent"
|
|
||||||
:options="props.options"
|
|
||||||
:modelValue="props.modelValue"
|
|
||||||
@update:modelValue="emit('update:modelValue', $event)"
|
|
||||||
/>
|
|
||||||
</template>
|
|
||||||
|
|
||||||
<style scoped lang="scss"></style>
|
|
@ -1,207 +0,0 @@
|
|||||||
<template>
|
|
||||||
<div class="custom-select-wrapper" v-click-outside="closeDropdown">
|
|
||||||
<div class="custom-select-display" @click="toggleDropdown">
|
|
||||||
<span class="selected-text">{{ selectedLabel }}</span>
|
|
||||||
<div class="select-arrow" :class="{ open: isOpen }">
|
|
||||||
<svg width="10" height="5" viewBox="0 0 10 5" fill="none">
|
|
||||||
<path
|
|
||||||
d="M1 1L5 4L9 1"
|
|
||||||
stroke="#455363"
|
|
||||||
stroke-width="1.5"
|
|
||||||
stroke-linecap="round"
|
|
||||||
stroke-linejoin="round"
|
|
||||||
/>
|
|
||||||
</svg>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<transition name="dropdown">
|
|
||||||
<div v-if="isOpen" class="custom-select-dropdown">
|
|
||||||
<div
|
|
||||||
v-for="option in props.options"
|
|
||||||
:key="option.value"
|
|
||||||
class="custom-select-option"
|
|
||||||
:class="{ selected: option.value === props.modelValue }"
|
|
||||||
@click="selectOption(option.value)"
|
|
||||||
>
|
|
||||||
{{ option.label }}
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</transition>
|
|
||||||
</div>
|
|
||||||
</template>
|
|
||||||
|
|
||||||
<script setup>
|
|
||||||
import { ref, computed } from "vue";
|
|
||||||
|
|
||||||
const props = defineProps({
|
|
||||||
options: {
|
|
||||||
type: Array,
|
|
||||||
required: true,
|
|
||||||
},
|
|
||||||
modelValue: {
|
|
||||||
type: [String, Number],
|
|
||||||
required: true,
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
const emit = defineEmits(["update:modelValue"]);
|
|
||||||
|
|
||||||
const isOpen = ref(false);
|
|
||||||
|
|
||||||
const selectedLabel = computed(() => {
|
|
||||||
const option = props.options.find((opt) => opt.value === props.modelValue);
|
|
||||||
return option ? option.label : "";
|
|
||||||
});
|
|
||||||
|
|
||||||
const toggleDropdown = () => {
|
|
||||||
isOpen.value = !isOpen.value;
|
|
||||||
};
|
|
||||||
|
|
||||||
const closeDropdown = () => {
|
|
||||||
isOpen.value = false;
|
|
||||||
};
|
|
||||||
|
|
||||||
const selectOption = (value) => {
|
|
||||||
emit("update:modelValue", value);
|
|
||||||
closeDropdown();
|
|
||||||
};
|
|
||||||
|
|
||||||
// 点击外部关闭下拉菜单
|
|
||||||
const vClickOutside = {
|
|
||||||
mounted(el, binding) {
|
|
||||||
el.clickOutsideEvent = (event) => {
|
|
||||||
if (!(el === event.target || el.contains(event.target))) {
|
|
||||||
binding.value();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
document.addEventListener("click", el.clickOutsideEvent);
|
|
||||||
},
|
|
||||||
unmounted(el) {
|
|
||||||
document.removeEventListener("click", el.clickOutsideEvent);
|
|
||||||
},
|
|
||||||
};
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<style scoped lang="scss">
|
|
||||||
.custom-select-wrapper {
|
|
||||||
position: relative;
|
|
||||||
width: 100%;
|
|
||||||
height: 46px;
|
|
||||||
user-select: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
.custom-select-display {
|
|
||||||
width: 100%;
|
|
||||||
height: 100%;
|
|
||||||
padding: 7px 36px 7px 12px;
|
|
||||||
border: 1px solid #e0e0e6;
|
|
||||||
border-radius: 3px;
|
|
||||||
background: #fff;
|
|
||||||
font-family: "PingFang SC", sans-serif;
|
|
||||||
font-weight: 400;
|
|
||||||
font-size: 16px;
|
|
||||||
line-height: 1.375em;
|
|
||||||
letter-spacing: 0.03em;
|
|
||||||
color: #455363;
|
|
||||||
cursor: pointer;
|
|
||||||
box-sizing: border-box;
|
|
||||||
display: flex;
|
|
||||||
align-items: center;
|
|
||||||
justify-content: space-between;
|
|
||||||
position: relative;
|
|
||||||
|
|
||||||
&:hover {
|
|
||||||
border-color: #ff7bac;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.selected-text {
|
|
||||||
flex: 1;
|
|
||||||
overflow: hidden;
|
|
||||||
text-overflow: ellipsis;
|
|
||||||
white-space: nowrap;
|
|
||||||
}
|
|
||||||
|
|
||||||
.select-arrow {
|
|
||||||
position: absolute;
|
|
||||||
right: 12px;
|
|
||||||
top: 50%;
|
|
||||||
transform: translateY(-50%);
|
|
||||||
display: flex;
|
|
||||||
align-items: center;
|
|
||||||
justify-content: center;
|
|
||||||
transition: transform 0.3s ease;
|
|
||||||
|
|
||||||
&.open {
|
|
||||||
transform: translateY(-50%) rotate(180deg);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.custom-select-dropdown {
|
|
||||||
position: absolute;
|
|
||||||
top: calc(100% + 4px);
|
|
||||||
left: 0;
|
|
||||||
right: 0;
|
|
||||||
max-height: 300px;
|
|
||||||
overflow-y: auto;
|
|
||||||
background: #fff;
|
|
||||||
border: 1px solid #e0e0e6;
|
|
||||||
border-radius: 3px;
|
|
||||||
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
|
|
||||||
z-index: 1000;
|
|
||||||
|
|
||||||
// 自定义滚动条样式
|
|
||||||
&::-webkit-scrollbar {
|
|
||||||
width: 8px;
|
|
||||||
}
|
|
||||||
|
|
||||||
&::-webkit-scrollbar-track {
|
|
||||||
background: #f1f1f1;
|
|
||||||
border-radius: 4px;
|
|
||||||
}
|
|
||||||
|
|
||||||
&::-webkit-scrollbar-thumb {
|
|
||||||
background: #ccc;
|
|
||||||
border-radius: 4px;
|
|
||||||
}
|
|
||||||
|
|
||||||
&::-webkit-scrollbar-thumb:hover {
|
|
||||||
background: #fff0f5;
|
|
||||||
cursor: pointer;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.custom-select-option {
|
|
||||||
padding: 8px 12px;
|
|
||||||
font-family: "PingFang SC", sans-serif;
|
|
||||||
font-weight: 400;
|
|
||||||
font-size: 16px;
|
|
||||||
cursor: pointer;
|
|
||||||
transition: background 0.2s ease;
|
|
||||||
background: #fff;
|
|
||||||
&:hover {
|
|
||||||
background: rgba(204, 204, 204, 0.2);
|
|
||||||
}
|
|
||||||
|
|
||||||
&.selected {
|
|
||||||
color: #ff7bac;
|
|
||||||
font-weight: 500;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// 下拉动画
|
|
||||||
.dropdown-enter-active,
|
|
||||||
.dropdown-leave-active {
|
|
||||||
transition: opacity 0.2s ease, transform 0.2s ease;
|
|
||||||
}
|
|
||||||
|
|
||||||
.dropdown-enter-from {
|
|
||||||
opacity: 0;
|
|
||||||
transform: translateY(-10px);
|
|
||||||
}
|
|
||||||
|
|
||||||
.dropdown-leave-to {
|
|
||||||
opacity: 0;
|
|
||||||
transform: translateY(-10px);
|
|
||||||
}
|
|
||||||
</style>
|
|
@ -1,207 +0,0 @@
|
|||||||
<template>
|
|
||||||
<div class="custom-select-wrapper" v-click-outside="closeDropdown">
|
|
||||||
<div class="custom-select-display" @click="toggleDropdown">
|
|
||||||
<span class="selected-text">{{ selectedLabel }}</span>
|
|
||||||
<div class="select-arrow" :class="{ open: isOpen }">
|
|
||||||
<svg width="10" height="5" viewBox="0 0 10 5" fill="none">
|
|
||||||
<path
|
|
||||||
d="M1 1L5 4L9 1"
|
|
||||||
stroke="#455363"
|
|
||||||
stroke-width="1.5"
|
|
||||||
stroke-linecap="round"
|
|
||||||
stroke-linejoin="round"
|
|
||||||
/>
|
|
||||||
</svg>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<transition name="dropdown">
|
|
||||||
<div v-if="isOpen" class="custom-select-dropdown">
|
|
||||||
<div
|
|
||||||
v-for="option in props.options"
|
|
||||||
:key="option.value"
|
|
||||||
class="custom-select-option"
|
|
||||||
:class="{ selected: option.value === props.modelValue }"
|
|
||||||
@click="selectOption(option.value)"
|
|
||||||
>
|
|
||||||
{{ option.label }}
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</transition>
|
|
||||||
</div>
|
|
||||||
</template>
|
|
||||||
|
|
||||||
<script setup>
|
|
||||||
import { ref, computed } from "vue";
|
|
||||||
|
|
||||||
const props = defineProps({
|
|
||||||
options: {
|
|
||||||
type: Array,
|
|
||||||
required: true,
|
|
||||||
},
|
|
||||||
modelValue: {
|
|
||||||
type: [String, Number],
|
|
||||||
required: true,
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
const emit = defineEmits(["update:modelValue"]);
|
|
||||||
|
|
||||||
const isOpen = ref(false);
|
|
||||||
|
|
||||||
const selectedLabel = computed(() => {
|
|
||||||
const option = props.options.find((opt) => opt.value === props.modelValue);
|
|
||||||
return option ? option.label : "";
|
|
||||||
});
|
|
||||||
|
|
||||||
const toggleDropdown = () => {
|
|
||||||
isOpen.value = !isOpen.value;
|
|
||||||
};
|
|
||||||
|
|
||||||
const closeDropdown = () => {
|
|
||||||
isOpen.value = false;
|
|
||||||
};
|
|
||||||
|
|
||||||
const selectOption = (value) => {
|
|
||||||
emit("update:modelValue", value);
|
|
||||||
closeDropdown();
|
|
||||||
};
|
|
||||||
|
|
||||||
// 点击外部关闭下拉菜单
|
|
||||||
const vClickOutside = {
|
|
||||||
mounted(el, binding) {
|
|
||||||
el.clickOutsideEvent = (event) => {
|
|
||||||
if (!(el === event.target || el.contains(event.target))) {
|
|
||||||
binding.value();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
document.addEventListener("click", el.clickOutsideEvent);
|
|
||||||
},
|
|
||||||
unmounted(el) {
|
|
||||||
document.removeEventListener("click", el.clickOutsideEvent);
|
|
||||||
},
|
|
||||||
};
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<style scoped lang="scss">
|
|
||||||
.custom-select-wrapper {
|
|
||||||
position: relative;
|
|
||||||
width: 100%;
|
|
||||||
height: 34px;
|
|
||||||
user-select: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
.custom-select-display {
|
|
||||||
width: 100%;
|
|
||||||
height: 100%;
|
|
||||||
padding: 7px 36px 7px 12px;
|
|
||||||
border: 1px solid #e0e0e6;
|
|
||||||
border-radius: 3px;
|
|
||||||
background: #fff;
|
|
||||||
font-family: "PingFang SC", sans-serif;
|
|
||||||
font-weight: 400;
|
|
||||||
font-size: 16px;
|
|
||||||
line-height: 1.375em;
|
|
||||||
letter-spacing: 0.03em;
|
|
||||||
color: #455363;
|
|
||||||
cursor: pointer;
|
|
||||||
box-sizing: border-box;
|
|
||||||
display: flex;
|
|
||||||
align-items: center;
|
|
||||||
justify-content: space-between;
|
|
||||||
position: relative;
|
|
||||||
|
|
||||||
&:hover {
|
|
||||||
border-color: #ff7bac;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.selected-text {
|
|
||||||
flex: 1;
|
|
||||||
overflow: hidden;
|
|
||||||
text-overflow: ellipsis;
|
|
||||||
white-space: nowrap;
|
|
||||||
}
|
|
||||||
|
|
||||||
.select-arrow {
|
|
||||||
position: absolute;
|
|
||||||
right: 12px;
|
|
||||||
top: 50%;
|
|
||||||
transform: translateY(-50%);
|
|
||||||
display: flex;
|
|
||||||
align-items: center;
|
|
||||||
justify-content: center;
|
|
||||||
transition: transform 0.3s ease;
|
|
||||||
|
|
||||||
&.open {
|
|
||||||
transform: translateY(-50%) rotate(180deg);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.custom-select-dropdown {
|
|
||||||
position: absolute;
|
|
||||||
top: calc(100% + 4px);
|
|
||||||
left: 0;
|
|
||||||
right: 0;
|
|
||||||
max-height: 300px;
|
|
||||||
overflow-y: auto;
|
|
||||||
background: #fff;
|
|
||||||
border: 1px solid #e0e0e6;
|
|
||||||
border-radius: 3px;
|
|
||||||
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
|
|
||||||
z-index: 1000;
|
|
||||||
|
|
||||||
// 自定义滚动条样式
|
|
||||||
&::-webkit-scrollbar {
|
|
||||||
width: 8px;
|
|
||||||
}
|
|
||||||
|
|
||||||
&::-webkit-scrollbar-track {
|
|
||||||
background: #f1f1f1;
|
|
||||||
border-radius: 4px;
|
|
||||||
}
|
|
||||||
|
|
||||||
&::-webkit-scrollbar-thumb {
|
|
||||||
background: #ccc;
|
|
||||||
border-radius: 4px;
|
|
||||||
}
|
|
||||||
|
|
||||||
&::-webkit-scrollbar-thumb:hover {
|
|
||||||
background: #fff0f5;
|
|
||||||
cursor: pointer;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.custom-select-option {
|
|
||||||
padding: 8px 12px;
|
|
||||||
font-family: "PingFang SC", sans-serif;
|
|
||||||
font-weight: 400;
|
|
||||||
font-size: 16px;
|
|
||||||
cursor: pointer;
|
|
||||||
transition: background 0.2s ease;
|
|
||||||
background: #fff;
|
|
||||||
&:hover {
|
|
||||||
background: rgba(204, 204, 204, 0.2);
|
|
||||||
}
|
|
||||||
|
|
||||||
&.selected {
|
|
||||||
color: #ff7bac;
|
|
||||||
font-weight: 500;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// 下拉动画
|
|
||||||
.dropdown-enter-active,
|
|
||||||
.dropdown-leave-active {
|
|
||||||
transition: opacity 0.2s ease, transform 0.2s ease;
|
|
||||||
}
|
|
||||||
|
|
||||||
.dropdown-enter-from {
|
|
||||||
opacity: 0;
|
|
||||||
transform: translateY(-10px);
|
|
||||||
}
|
|
||||||
|
|
||||||
.dropdown-leave-to {
|
|
||||||
opacity: 0;
|
|
||||||
transform: translateY(-10px);
|
|
||||||
}
|
|
||||||
</style>
|
|
@ -1,116 +0,0 @@
|
|||||||
<template>
|
|
||||||
<div class="custom-select-mobile">
|
|
||||||
<div class="search-select" @click="openYearPicker">
|
|
||||||
<div class="search-select-label">Year</div>
|
|
||||||
<div class="search-select-icon">
|
|
||||||
<span class="selected-year-label">{{ selectedLabel }}</span>
|
|
||||||
<svg
|
|
||||||
xmlns="http://www.w3.org/2000/svg"
|
|
||||||
width="10"
|
|
||||||
height="10"
|
|
||||||
viewBox="0 0 10 10"
|
|
||||||
fill="none"
|
|
||||||
>
|
|
||||||
<path
|
|
||||||
fill-rule="evenodd"
|
|
||||||
clip-rule="evenodd"
|
|
||||||
d="M2.58882 9.69047C2.38633 9.48798 2.36383 9.17365 2.52132 8.9463L2.58882 8.86552L6.45447 5.00022L2.58882 1.13492C2.38633 0.932428 2.36383 0.618098 2.52132 0.390748L2.58882 0.309958C2.79132 0.107469 3.10565 0.0849685 3.33299 0.242458L3.41378 0.309958L7.69156 4.58774C7.89405 4.79023 7.91655 5.10456 7.75906 5.33191L7.69156 5.4127L3.41378 9.69047C3.18597 9.91828 2.81663 9.91828 2.58882 9.69047Z"
|
|
||||||
fill="black"
|
|
||||||
/>
|
|
||||||
</svg>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<year-wheel-picker
|
|
||||||
v-if="showYearPicker"
|
|
||||||
v-model="localValue"
|
|
||||||
:options="props.options"
|
|
||||||
@close="closeYearPicker"
|
|
||||||
@confirm="onYearConfirm"
|
|
||||||
></year-wheel-picker>
|
|
||||||
</div>
|
|
||||||
</template>
|
|
||||||
|
|
||||||
<script setup>
|
|
||||||
import { ref, computed } from "vue";
|
|
||||||
import YearWheelPicker from "@/components/YearWheelPicker.vue";
|
|
||||||
|
|
||||||
const props = defineProps({
|
|
||||||
options: {
|
|
||||||
type: Array,
|
|
||||||
required: true,
|
|
||||||
},
|
|
||||||
modelValue: {
|
|
||||||
type: [String, Number],
|
|
||||||
required: true,
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
const emit = defineEmits(["update:modelValue"]);
|
|
||||||
|
|
||||||
const showYearPicker = ref(false);
|
|
||||||
const localValue = ref(props.modelValue);
|
|
||||||
|
|
||||||
const selectedLabel = computed(() => {
|
|
||||||
const option = props.options.find((opt) => opt.value === props.modelValue);
|
|
||||||
return option ? option.label : "";
|
|
||||||
});
|
|
||||||
|
|
||||||
const openYearPicker = () => {
|
|
||||||
localValue.value = props.modelValue;
|
|
||||||
showYearPicker.value = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
const closeYearPicker = () => {
|
|
||||||
showYearPicker.value = false;
|
|
||||||
};
|
|
||||||
|
|
||||||
const onYearConfirm = (year) => {
|
|
||||||
emit("update:modelValue", year);
|
|
||||||
closeYearPicker();
|
|
||||||
};
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<style scoped lang="scss">
|
|
||||||
.custom-select-mobile {
|
|
||||||
width: 100%;
|
|
||||||
}
|
|
||||||
|
|
||||||
.search-select {
|
|
||||||
width: 100%;
|
|
||||||
height: 34 * 5.12px;
|
|
||||||
padding: 0 12px;
|
|
||||||
display: flex;
|
|
||||||
align-items: center;
|
|
||||||
justify-content: space-between;
|
|
||||||
cursor: pointer;
|
|
||||||
font-family: "PingFang SC", sans-serif;
|
|
||||||
font-weight: 400;
|
|
||||||
font-size: 14 * 5.12px;
|
|
||||||
color: #455363;
|
|
||||||
border: 1 * 5.12px solid #e0e0e6;
|
|
||||||
border-radius: 3 * 5.12px;
|
|
||||||
background: #fff;
|
|
||||||
}
|
|
||||||
|
|
||||||
.search-select-icon {
|
|
||||||
display: flex;
|
|
||||||
align-items: center;
|
|
||||||
gap: 8 * 5.12px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.selected-year-label {
|
|
||||||
font-family: "PingFang SC", sans-serif;
|
|
||||||
font-weight: 400;
|
|
||||||
font-size: 14 * 5.12px;
|
|
||||||
line-height: 1.428em;
|
|
||||||
color: #000;
|
|
||||||
}
|
|
||||||
|
|
||||||
.search-select-label {
|
|
||||||
font-family: "PingFang SC", sans-serif;
|
|
||||||
font-weight: 400;
|
|
||||||
font-size: 14 * 5.12px;
|
|
||||||
line-height: 1.428em;
|
|
||||||
color: #000;
|
|
||||||
}
|
|
||||||
</style>
|
|
@ -1,207 +0,0 @@
|
|||||||
<template>
|
|
||||||
<div class="custom-select-wrapper" v-click-outside="closeDropdown">
|
|
||||||
<div class="custom-select-display" @click="toggleDropdown">
|
|
||||||
<span class="selected-text">{{ selectedLabel }}</span>
|
|
||||||
<div class="select-arrow" :class="{ open: isOpen }">
|
|
||||||
<svg width="10" height="5" viewBox="0 0 10 5" fill="none">
|
|
||||||
<path
|
|
||||||
d="M1 1L5 4L9 1"
|
|
||||||
stroke="#455363"
|
|
||||||
stroke-width="1.5"
|
|
||||||
stroke-linecap="round"
|
|
||||||
stroke-linejoin="round"
|
|
||||||
/>
|
|
||||||
</svg>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<transition name="dropdown">
|
|
||||||
<div v-if="isOpen" class="custom-select-dropdown">
|
|
||||||
<div
|
|
||||||
v-for="option in props.options"
|
|
||||||
:key="option.value"
|
|
||||||
class="custom-select-option"
|
|
||||||
:class="{ selected: option.value === props.modelValue }"
|
|
||||||
@click="selectOption(option.value)"
|
|
||||||
>
|
|
||||||
{{ option.label }}
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</transition>
|
|
||||||
</div>
|
|
||||||
</template>
|
|
||||||
|
|
||||||
<script setup>
|
|
||||||
import { ref, computed } from "vue";
|
|
||||||
|
|
||||||
const props = defineProps({
|
|
||||||
options: {
|
|
||||||
type: Array,
|
|
||||||
required: true,
|
|
||||||
},
|
|
||||||
modelValue: {
|
|
||||||
type: [String, Number],
|
|
||||||
required: true,
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
const emit = defineEmits(["update:modelValue"]);
|
|
||||||
|
|
||||||
const isOpen = ref(false);
|
|
||||||
|
|
||||||
const selectedLabel = computed(() => {
|
|
||||||
const option = props.options.find((opt) => opt.value === props.modelValue);
|
|
||||||
return option ? option.label : "";
|
|
||||||
});
|
|
||||||
|
|
||||||
const toggleDropdown = () => {
|
|
||||||
isOpen.value = !isOpen.value;
|
|
||||||
};
|
|
||||||
|
|
||||||
const closeDropdown = () => {
|
|
||||||
isOpen.value = false;
|
|
||||||
};
|
|
||||||
|
|
||||||
const selectOption = (value) => {
|
|
||||||
emit("update:modelValue", value);
|
|
||||||
closeDropdown();
|
|
||||||
};
|
|
||||||
|
|
||||||
// 点击外部关闭下拉菜单
|
|
||||||
const vClickOutside = {
|
|
||||||
mounted(el, binding) {
|
|
||||||
el.clickOutsideEvent = (event) => {
|
|
||||||
if (!(el === event.target || el.contains(event.target))) {
|
|
||||||
binding.value();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
document.addEventListener("click", el.clickOutsideEvent);
|
|
||||||
},
|
|
||||||
unmounted(el) {
|
|
||||||
document.removeEventListener("click", el.clickOutsideEvent);
|
|
||||||
},
|
|
||||||
};
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<style scoped lang="scss">
|
|
||||||
.custom-select-wrapper {
|
|
||||||
position: relative;
|
|
||||||
width: 100%;
|
|
||||||
height: 34 * 2.5px;
|
|
||||||
user-select: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
.custom-select-display {
|
|
||||||
width: 100%;
|
|
||||||
height: 100%;
|
|
||||||
padding: 7 * 2.5px 36 * 2.5px 7 * 2.5px 12 * 2.5px;
|
|
||||||
border: 1 * 2.5px solid #e0e0e6;
|
|
||||||
border-radius: 3 * 2.5px;
|
|
||||||
background: #fff;
|
|
||||||
font-family: "PingFang SC", sans-serif;
|
|
||||||
font-weight: 400;
|
|
||||||
font-size: 14 * 2.5px;
|
|
||||||
line-height: 1.375em;
|
|
||||||
letter-spacing: 0.48 * 2.5px;
|
|
||||||
color: #455363;
|
|
||||||
cursor: pointer;
|
|
||||||
box-sizing: border-box;
|
|
||||||
display: flex;
|
|
||||||
align-items: center;
|
|
||||||
justify-content: space-between;
|
|
||||||
position: relative;
|
|
||||||
|
|
||||||
&:hover {
|
|
||||||
border-color: #ff7bac;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.selected-text {
|
|
||||||
flex: 1;
|
|
||||||
overflow: hidden;
|
|
||||||
text-overflow: ellipsis;
|
|
||||||
white-space: nowrap;
|
|
||||||
}
|
|
||||||
|
|
||||||
.select-arrow {
|
|
||||||
position: absolute;
|
|
||||||
right: 12 * 2.5px;
|
|
||||||
top: 50%;
|
|
||||||
transform: translateY(-50%);
|
|
||||||
display: flex;
|
|
||||||
align-items: center;
|
|
||||||
justify-content: center;
|
|
||||||
transition: transform 0.3s ease;
|
|
||||||
|
|
||||||
&.open {
|
|
||||||
transform: translateY(-50%) rotate(180deg);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.custom-select-dropdown {
|
|
||||||
position: absolute;
|
|
||||||
top: calc(100% + 4 * 2.5px);
|
|
||||||
left: 0;
|
|
||||||
right: 0;
|
|
||||||
max-height: 300 * 2.5px;
|
|
||||||
overflow-y: auto;
|
|
||||||
background: #fff;
|
|
||||||
border: 1 * 2.5px solid #e0e0e6;
|
|
||||||
border-radius: 3 * 2.5px;
|
|
||||||
box-shadow: 0 2 * 2.5px 8 * 2.5px rgba(0, 0, 0, 0.1);
|
|
||||||
z-index: 1000;
|
|
||||||
|
|
||||||
// 自定义滚动条样式
|
|
||||||
&::-webkit-scrollbar {
|
|
||||||
width: 5 * 2.5px;
|
|
||||||
}
|
|
||||||
|
|
||||||
&::-webkit-scrollbar-track {
|
|
||||||
background: #f1f1f1;
|
|
||||||
border-radius: 4 * 2.5px;
|
|
||||||
}
|
|
||||||
|
|
||||||
&::-webkit-scrollbar-thumb {
|
|
||||||
background: #ccc;
|
|
||||||
border-radius: 4 * 2.5px;
|
|
||||||
}
|
|
||||||
|
|
||||||
&::-webkit-scrollbar-thumb:hover {
|
|
||||||
background: #fff0f5;
|
|
||||||
cursor: pointer;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.custom-select-option {
|
|
||||||
padding: 8 * 2.5px 12 * 2.5px;
|
|
||||||
font-family: "PingFang SC", sans-serif;
|
|
||||||
font-weight: 400;
|
|
||||||
font-size: 14 * 2.5px;
|
|
||||||
cursor: pointer;
|
|
||||||
transition: background 0.2s ease;
|
|
||||||
background: #fff;
|
|
||||||
&:hover {
|
|
||||||
background: rgba(204, 204, 204, 0.2);
|
|
||||||
}
|
|
||||||
|
|
||||||
&.selected {
|
|
||||||
color: #ff7bac;
|
|
||||||
font-weight: 500;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// 下拉动画
|
|
||||||
.dropdown-enter-active,
|
|
||||||
.dropdown-leave-active {
|
|
||||||
transition: opacity 0.2s ease, transform 0.2s ease;
|
|
||||||
}
|
|
||||||
|
|
||||||
.dropdown-enter-from {
|
|
||||||
opacity: 0;
|
|
||||||
transform: translateY(-10 * 2.5px);
|
|
||||||
}
|
|
||||||
|
|
||||||
.dropdown-leave-to {
|
|
||||||
opacity: 0;
|
|
||||||
transform: translateY(-10 * 2.5px);
|
|
||||||
}
|
|
||||||
</style>
|
|
@ -17,9 +17,9 @@ const viewComponent = computed(() => {
|
|||||||
const viewWidth = width.value;
|
const viewWidth = width.value;
|
||||||
if (viewWidth <= 450) {
|
if (viewWidth <= 450) {
|
||||||
return size375;
|
return size375;
|
||||||
} else if (viewWidth <= 1100) {
|
} else if (viewWidth <= 835) {
|
||||||
return size768;
|
return size768;
|
||||||
} else if (viewWidth <= 1500) {
|
} else if (viewWidth <= 1640) {
|
||||||
return size1440;
|
return size1440;
|
||||||
} else if (viewWidth <= 1920 || viewWidth > 1920) {
|
} else if (viewWidth <= 1920 || viewWidth > 1920) {
|
||||||
return size1920;
|
return size1920;
|
||||||
|
@ -85,8 +85,6 @@ export default {
|
|||||||
"5y": "5Y",
|
"5y": "5Y",
|
||||||
"10y": "10Y",
|
"10y": "10Y",
|
||||||
max: "Max",
|
max: "Max",
|
||||||
start_time: "Start Time",
|
|
||||||
end_time: "End Time",
|
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
header_menu: {
|
header_menu: {
|
||||||
@ -137,89 +135,4 @@ export default {
|
|||||||
button: "Go",
|
button: "Go",
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
product_intro: {
|
|
||||||
hero_line1: "More than just a tool——",
|
|
||||||
hero_line2: "Comprehensive growth solutions, ",
|
|
||||||
hero_line3: "providing a one-stop solution for content creation,",
|
|
||||||
hero_line4: "publishing, analysis, and monetization",
|
|
||||||
core_value_title: "Core Value",
|
|
||||||
core_value_text:
|
|
||||||
"The FIEE-SAAS platform is a one-stop content operation solution tailored for creators in the digital era. The platform utilizes intelligent distribution technology, A1 empowerment tools, and full-chain services,Assist you in efficiently reaching audiences on global mainstream platforms such as TikTok, YouTube, and Instagram, creating a KOL brand effect, unlocking content value, and achieving sustainable growth.",
|
|
||||||
features_title: "Product Features",
|
|
||||||
feature_sync: "One-click Synchronous Publishing",
|
|
||||||
feature_sync_desc:
|
|
||||||
"Synchronize graphic and video content to TikTok, YouTube, and Instagram platforms at once, saving time on repetitive operations.",
|
|
||||||
feature_schedule: "Intelligent Scheduled Publishing",
|
|
||||||
feature_schedule_desc:
|
|
||||||
"Plan the content release time in advance, support batch scheduling, and accurately grasp the optimal release time of each platform.",
|
|
||||||
feature_accounts: "Unified Management of Multiple Accounts",
|
|
||||||
feature_accounts_desc:
|
|
||||||
"Easily manage multiple accounts on one platform without the need for repeated login and switching, improving team collaboration efficiency.",
|
|
||||||
feature_library: "Cloud Content Library",
|
|
||||||
feature_library_desc:
|
|
||||||
"Safely store and manage all creative materials, access and use them anytime, anywhere, and support quick retrieval and reuse.",
|
|
||||||
feature_tracking: "Basic Data Tracking",
|
|
||||||
feature_tracking_desc:
|
|
||||||
"Visually view the content performance of various platforms, understand core data indicators, and provide a basis for optimizing strategies.",
|
|
||||||
solutions_title: "Value Added Solutions",
|
|
||||||
sol_kol: "KOL Brand Promotion Services",
|
|
||||||
sol_kol_desc:
|
|
||||||
"Efficiently connect high-quality business cooperation opportunities and complete the entire process management from order acceptance to publication within the platform.",
|
|
||||||
sol_content: "Professional Content Creation Support",
|
|
||||||
sol_content_desc:
|
|
||||||
"Connect professional shooting and post production teams for you, create high-quality \"art+story\" content, and strengthen IP influence.",
|
|
||||||
sol_ops: "Account Operation and Hosting Services",
|
|
||||||
sol_ops_desc:
|
|
||||||
"From 0 to 1 account positioning, follower growth strategy to monetization cycle, operation experts provide full cycle running and hosting services.",
|
|
||||||
advantages_title: "Our Advantages",
|
|
||||||
adv_time: "Time Saving",
|
|
||||||
adv_time_desc:
|
|
||||||
"Multi platform publishing efficiency improvement, allowing you to focus on content creation.",
|
|
||||||
adv_safe: "Safe and Reliable",
|
|
||||||
adv_safe_desc:
|
|
||||||
"Enterprise level data encryption and permission control ensure account and content security.",
|
|
||||||
adv_consistent: "Maintain Consistency",
|
|
||||||
adv_consistent_desc:
|
|
||||||
"Ensure that brand information is presented uniformly on all platforms.",
|
|
||||||
adv_data: "Data Driven",
|
|
||||||
adv_data_desc:
|
|
||||||
"Optimizing Content Strategies Based on Actual Performance.",
|
|
||||||
adv_easy: "Easy to Use",
|
|
||||||
adv_easy_desc:
|
|
||||||
"Intuitive interface design, no need for professional technical background.",
|
|
||||||
cta_title_line1: "Get customized ",
|
|
||||||
cta_title_line2: "solutions for free",
|
|
||||||
},
|
|
||||||
contacts: {
|
|
||||||
title: "Investor Contacts",
|
|
||||||
company_name: "FiEE Inc.",
|
|
||||||
investor_relations: "Investor Relations",
|
|
||||||
email_label: "Email:",
|
|
||||||
},
|
|
||||||
email_alerts: {
|
|
||||||
title: "E-Mail Alerts",
|
|
||||||
required_fields: "* Required Fields",
|
|
||||||
submitted_successfully: "Submitted successfully!",
|
|
||||||
submitted_info: "The information you submitted is as follows:",
|
|
||||||
form: {
|
|
||||||
first_name: "* First Name",
|
|
||||||
last_name: "* Last Name",
|
|
||||||
email: "* Email",
|
|
||||||
company: "* Company",
|
|
||||||
phone: "* Phone",
|
|
||||||
submit: "Submit",
|
|
||||||
},
|
|
||||||
submitted_data: {
|
|
||||||
first_name: "First Name:",
|
|
||||||
last_name: "Last Name:",
|
|
||||||
email: "Email:",
|
|
||||||
company: "Company:",
|
|
||||||
phone: "Phone:",
|
|
||||||
not_filled: "Not filled in",
|
|
||||||
},
|
|
||||||
validation: {
|
|
||||||
complete_info: "Please fill in complete information",
|
|
||||||
field_length: "Field length cannot exceed 50 characters",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
};
|
};
|
||||||
|
@ -85,8 +85,6 @@ export default {
|
|||||||
"5y": "5年",
|
"5y": "5年",
|
||||||
"10y": "10年",
|
"10y": "10年",
|
||||||
"max": "最大",
|
"max": "最大",
|
||||||
start_time: "開始時間",
|
|
||||||
end_time: "終了時間",
|
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
header_menu: {
|
header_menu: {
|
||||||
@ -137,87 +135,4 @@ export default {
|
|||||||
button: "検索",
|
button: "検索",
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
product_intro: {
|
|
||||||
hero_line1: "単なるツールではなく——",
|
|
||||||
hero_line2: "包括的な成長ソリューション、",
|
|
||||||
hero_line3: "コンテンツ制作のワンストップソリューションを提供し、",
|
|
||||||
hero_line4: "配信・分析・マネタイズまで対応",
|
|
||||||
core_value_title: "中核価値",
|
|
||||||
core_value_text:
|
|
||||||
"FIEE-SAASプラットフォームは、デジタル時代のクリエイター向けに設計されたワンストップのコンテンツ運用ソリューションです。インテリジェント配信技術、AI支援ツール、フルチェーンサービスを活用し、TikTok、YouTube、Instagramなどの主要プラットフォームで効率的にオーディエンスにリーチし、KOLブランド効果を創出し、コンテンツ価値を解放し、持続的な成長を実現します。",
|
|
||||||
features_title: "製品機能",
|
|
||||||
feature_sync: "ワンクリック同時投稿",
|
|
||||||
feature_sync_desc:
|
|
||||||
"画像・動画コンテンツをTikTok、YouTube、Instagramに一括同期し、繰り返し作業の時間を削減します。",
|
|
||||||
feature_schedule: "インテリジェント予約投稿",
|
|
||||||
feature_schedule_desc:
|
|
||||||
"事前に投稿時間を計画し、バッチ予約に対応。各プラットフォームの最適な投稿時間を正確に把握。",
|
|
||||||
feature_accounts: "複数アカウントの一元管理",
|
|
||||||
feature_accounts_desc:
|
|
||||||
"1つのプラットフォームで複数アカウントを簡単に管理。ログイン・切替の手間を省き、チーム協業効率を向上。",
|
|
||||||
feature_library: "クラウドコンテンツライブラリ",
|
|
||||||
feature_library_desc:
|
|
||||||
"すべての制作素材を安全に保管・管理。いつでもどこでもアクセス・利用可能で、迅速な検索と再利用をサポート。",
|
|
||||||
feature_tracking: "基本データトラッキング",
|
|
||||||
feature_tracking_desc:
|
|
||||||
"各プラットフォームのコンテンツ実績を可視化し、コア指標を把握。最適化の根拠を提供。",
|
|
||||||
solutions_title: "付加価値ソリューション",
|
|
||||||
sol_kol: "KOLブランドプロモーション",
|
|
||||||
sol_kol_desc:
|
|
||||||
"高品質なビジネス協業機会を効率的にマッチングし、受注から公開までの全工程をプラットフォーム内で完結。",
|
|
||||||
sol_content: "プロフェッショナルなコンテンツ制作支援",
|
|
||||||
sol_content_desc:
|
|
||||||
"撮影・編集の専門チームと連携し、高品質な“アート+ストーリー”コンテンツを制作し、IP影響力を強化。",
|
|
||||||
sol_ops: "アカウント運用・代行サービス",
|
|
||||||
sol_ops_desc:
|
|
||||||
"0から1までのアカウント設計、フォロワー成長戦略から収益化サイクルまで、運用専門家が一貫して支援。",
|
|
||||||
advantages_title: "私たちの強み",
|
|
||||||
adv_time: "時間の節約",
|
|
||||||
adv_time_desc:
|
|
||||||
"マルチプラットフォーム同時投稿で効率アップ。制作に集中できます。",
|
|
||||||
adv_safe: "安全で信頼できる",
|
|
||||||
adv_safe_desc:
|
|
||||||
"エンタープライズレベルのデータ暗号化と権限管理でアカウントとコンテンツを保護。",
|
|
||||||
adv_consistent: "一貫性の維持",
|
|
||||||
adv_consistent_desc:
|
|
||||||
"すべてのプラットフォームでブランド情報を統一的に提示。",
|
|
||||||
adv_data: "データドリブン",
|
|
||||||
adv_data_desc: "実績に基づく戦略最適化。",
|
|
||||||
adv_easy: "使いやすさ",
|
|
||||||
adv_easy_desc: "直感的なUIで専門知識不要。",
|
|
||||||
cta_title_line1: "無料で",
|
|
||||||
cta_title_line2: "カスタマイズされたソリューションを",
|
|
||||||
},
|
|
||||||
contacts: {
|
|
||||||
title: "投資家連絡先",
|
|
||||||
company_name: "FiEE Inc.",
|
|
||||||
investor_relations: "投資家関係",
|
|
||||||
email_label: "メール:",
|
|
||||||
},
|
|
||||||
email_alerts: {
|
|
||||||
title: "メールアラート",
|
|
||||||
required_fields: "* 必須項目",
|
|
||||||
submitted_successfully: "送信が完了しました!",
|
|
||||||
submitted_info: "送信された情報は以下の通りです:",
|
|
||||||
form: {
|
|
||||||
first_name: "* 名",
|
|
||||||
last_name: "* 姓",
|
|
||||||
email: "* メールアドレス",
|
|
||||||
company: "* 会社名",
|
|
||||||
phone: "* 電話番号",
|
|
||||||
submit: "送信",
|
|
||||||
},
|
|
||||||
submitted_data: {
|
|
||||||
first_name: "名:",
|
|
||||||
last_name: "姓:",
|
|
||||||
email: "メールアドレス:",
|
|
||||||
company: "会社名:",
|
|
||||||
phone: "電話番号:",
|
|
||||||
not_filled: "未入力",
|
|
||||||
},
|
|
||||||
validation: {
|
|
||||||
complete_info: "完全な情報を入力してください",
|
|
||||||
field_length: "フィールドの長さは50文字を超えることはできません",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
}
|
}
|
@ -85,8 +85,6 @@ export default {
|
|||||||
"5y": "5年",
|
"5y": "5年",
|
||||||
"10y": "10年",
|
"10y": "10年",
|
||||||
"max": "最大",
|
"max": "最大",
|
||||||
start_time: "開始時間",
|
|
||||||
end_time: "結束時間",
|
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
header_menu: {
|
header_menu: {
|
||||||
@ -137,84 +135,4 @@ export default {
|
|||||||
button: "開始",
|
button: "開始",
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
product_intro: {
|
|
||||||
hero_line1: "不僅是一個工具——",
|
|
||||||
hero_line2: "全鏈路成長解決方案,",
|
|
||||||
hero_line3: "為內容創作提供一站式方案,",
|
|
||||||
hero_line4: "涵蓋發布、分析與變現",
|
|
||||||
core_value_title: "核心價值",
|
|
||||||
core_value_text:
|
|
||||||
"FIEE-SAAS 平台是一個為數位時代創作者量身打造的一站式內容營運解決方案。平台透過智慧分發技術、AI 賦能工具與全鏈服務,協助你高效觸達 TikTok、YouTube、Instagram 等全球主流平台受眾,打造 KOL 品牌效應,釋放內容價值,實現永續成長。",
|
|
||||||
features_title: "產品功能",
|
|
||||||
feature_sync: "一鍵同步發布",
|
|
||||||
feature_sync_desc:
|
|
||||||
"圖文與影片內容一鍵同步至 TikTok、YouTube、Instagram,節省重複操作時間。",
|
|
||||||
feature_schedule: "智慧排程發布",
|
|
||||||
feature_schedule_desc:
|
|
||||||
"事先規劃發布時間,支援批量排程,精準掌握各平台最佳發布時段。",
|
|
||||||
feature_accounts: "多帳號統一管理",
|
|
||||||
feature_accounts_desc:
|
|
||||||
"在一個平台輕鬆管理多個帳號,無需反覆登入與切換,提升團隊協作效率。",
|
|
||||||
feature_library: "雲端素材庫",
|
|
||||||
feature_library_desc:
|
|
||||||
"安全儲存與管理所有創作素材,隨時隨地取用,支援快速檢索與再利用。",
|
|
||||||
feature_tracking: "基礎數據追蹤",
|
|
||||||
feature_tracking_desc:
|
|
||||||
"以視覺化方式查看各平台內容表現,掌握核心指標,為策略優化提供依據。",
|
|
||||||
solutions_title: "增值解決方案",
|
|
||||||
sol_kol: "KOL 品牌推廣服務",
|
|
||||||
sol_kol_desc:
|
|
||||||
"高效率對接優質商務合作機會,於平台內完成從接單到發布的全流程管理。",
|
|
||||||
sol_content: "專業內容創作支援",
|
|
||||||
sol_content_desc:
|
|
||||||
"為你對接專業拍攝與後製團隊,打造高品質「藝術+故事」內容,強化 IP 影響力。",
|
|
||||||
sol_ops: "帳號營運與代營運服務",
|
|
||||||
sol_ops_desc:
|
|
||||||
"從 0 到 1 的帳號定位、粉絲成長策略到變現循環,營運專家提供全週期營運與託管服務。",
|
|
||||||
advantages_title: "我們的優勢",
|
|
||||||
adv_time: "節省時間",
|
|
||||||
adv_time_desc: "多平台聯動提升發布效率,專注內容創作。",
|
|
||||||
adv_safe: "安全可靠",
|
|
||||||
adv_safe_desc: "企業級數據加密與權限控管,保障帳號與內容安全。",
|
|
||||||
adv_consistent: "維持一致性",
|
|
||||||
adv_consistent_desc: "確保品牌資訊在各平台一致呈現。",
|
|
||||||
adv_data: "數據驅動",
|
|
||||||
adv_data_desc: "根據實際表現優化內容策略。",
|
|
||||||
adv_easy: "易於使用",
|
|
||||||
adv_easy_desc: "直覺化介面設計,無需專業技術背景。",
|
|
||||||
cta_title_line1: "免費獲取",
|
|
||||||
cta_title_line2: "專屬客製化方案",
|
|
||||||
},
|
|
||||||
contacts: {
|
|
||||||
title: "投資者聯絡方式",
|
|
||||||
company_name: "FiEE Inc.",
|
|
||||||
investor_relations: "投資者關係",
|
|
||||||
email_label: "郵箱:",
|
|
||||||
},
|
|
||||||
email_alerts: {
|
|
||||||
title: "郵件提醒",
|
|
||||||
required_fields: "* 必填欄位",
|
|
||||||
submitted_successfully: "提交成功!",
|
|
||||||
submitted_info: "您提交的資訊如下:",
|
|
||||||
form: {
|
|
||||||
first_name: "* 名字",
|
|
||||||
last_name: "* 姓氏",
|
|
||||||
email: "* 郵箱",
|
|
||||||
company: "* 公司",
|
|
||||||
phone: "* 電話",
|
|
||||||
submit: "提交",
|
|
||||||
},
|
|
||||||
submitted_data: {
|
|
||||||
first_name: "名字:",
|
|
||||||
last_name: "姓氏:",
|
|
||||||
email: "郵箱:",
|
|
||||||
company: "公司:",
|
|
||||||
phone: "電話:",
|
|
||||||
not_filled: "未填寫",
|
|
||||||
},
|
|
||||||
validation: {
|
|
||||||
complete_info: "請填寫完整資訊",
|
|
||||||
field_length: "欄位長度不能超過50個字符",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
}
|
}
|
@ -85,8 +85,6 @@ export default {
|
|||||||
"5y": '5年',
|
"5y": '5年',
|
||||||
"10y": '10年',
|
"10y": '10年',
|
||||||
max: '最大',
|
max: '最大',
|
||||||
start_time: '开始时间',
|
|
||||||
end_time: '结束时间',
|
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
header_menu: {
|
header_menu: {
|
||||||
@ -137,84 +135,4 @@ export default {
|
|||||||
button: "开始",
|
button: "开始",
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
product_intro: {
|
|
||||||
hero_line1: "不止于工具——",
|
|
||||||
hero_line2: "全链路增长解决方案,",
|
|
||||||
hero_line3: "为内容创作提供一站式方案,",
|
|
||||||
hero_line4: "覆盖发布、分析与变现",
|
|
||||||
core_value_title: "核心价值",
|
|
||||||
core_value_text:
|
|
||||||
"FIEE-SAAS 平台是为数字时代创作者量身打造的一站式内容运营解决方案。平台通过智能分发技术、AI 赋能工具与全链路服务,助你高效触达 TikTok、YouTube、Instagram 等全球主流平台受众,打造 KOL 品牌效应,释放内容价值,实现可持续增长。",
|
|
||||||
features_title: "产品功能",
|
|
||||||
feature_sync: "一键同步发布",
|
|
||||||
feature_sync_desc:
|
|
||||||
"图文与视频内容一键同步至 TikTok、YouTube、Instagram,节省重复操作时间。",
|
|
||||||
feature_schedule: "智能定时发布",
|
|
||||||
feature_schedule_desc:
|
|
||||||
"提前规划内容发布时间,支持批量排期,精准把握各平台最佳发布时间。",
|
|
||||||
feature_accounts: "多账号统一管理",
|
|
||||||
feature_accounts_desc:
|
|
||||||
"一个平台轻松管理多个账号,无需反复登录与切换,提升团队协同效率。",
|
|
||||||
feature_library: "云端素材库",
|
|
||||||
feature_library_desc:
|
|
||||||
"安全存储与管理全部创作素材,随时随地访问与使用,支持快速检索与复用。",
|
|
||||||
feature_tracking: "基础数据追踪",
|
|
||||||
feature_tracking_desc:
|
|
||||||
"可视化查看各平台内容表现,掌握核心数据指标,为策略优化提供依据。",
|
|
||||||
solutions_title: "增值解决方案",
|
|
||||||
sol_kol: "KOL 品牌推广服务",
|
|
||||||
sol_kol_desc:
|
|
||||||
"高效对接优质商务合作机会,在平台内完成从接单到发布的全流程管理。",
|
|
||||||
sol_content: "专业内容创作支持",
|
|
||||||
sol_content_desc:
|
|
||||||
"为你对接专业拍摄与后期团队,打造高质量“艺术+故事”内容,强化 IP 影响力。",
|
|
||||||
sol_ops: "账号运营与代运营服务",
|
|
||||||
sol_ops_desc:
|
|
||||||
"从 0 到 1 账号定位、粉丝增长策略到变现闭环,运营专家提供全周期运营与托管服务。",
|
|
||||||
advantages_title: "我们的优势",
|
|
||||||
adv_time: "节省时间",
|
|
||||||
adv_time_desc: "多平台联动提升发布效率,专注内容创作。",
|
|
||||||
adv_safe: "安全可靠",
|
|
||||||
adv_safe_desc: "企业级数据加密与权限控制,保障账号与内容安全。",
|
|
||||||
adv_consistent: "保持一致性",
|
|
||||||
adv_consistent_desc: "确保品牌信息在各平台统一呈现。",
|
|
||||||
adv_data: "数据驱动",
|
|
||||||
adv_data_desc: "基于实际表现优化内容策略。",
|
|
||||||
adv_easy: "易于使用",
|
|
||||||
adv_easy_desc: "直观的界面设计,无需专业技术背景。",
|
|
||||||
cta_title_line1: "免费获取",
|
|
||||||
cta_title_line2: "专属定制方案",
|
|
||||||
},
|
|
||||||
contacts: {
|
|
||||||
title: "投资者联系方式",
|
|
||||||
company_name: "FiEE Inc.",
|
|
||||||
investor_relations: "投资者关系",
|
|
||||||
email_label: "邮箱:",
|
|
||||||
},
|
|
||||||
email_alerts: {
|
|
||||||
title: "邮件提醒",
|
|
||||||
required_fields: "* 必填字段",
|
|
||||||
submitted_successfully: "提交成功!",
|
|
||||||
submitted_info: "您提交的信息如下:",
|
|
||||||
form: {
|
|
||||||
first_name: "* 名字",
|
|
||||||
last_name: "* 姓氏",
|
|
||||||
email: "* 邮箱",
|
|
||||||
company: "* 公司",
|
|
||||||
phone: "* 电话",
|
|
||||||
submit: "提交",
|
|
||||||
},
|
|
||||||
submitted_data: {
|
|
||||||
first_name: "名字:",
|
|
||||||
last_name: "姓氏:",
|
|
||||||
email: "邮箱:",
|
|
||||||
company: "公司:",
|
|
||||||
phone: "电话:",
|
|
||||||
not_filled: "未填写",
|
|
||||||
},
|
|
||||||
validation: {
|
|
||||||
complete_info: "请填写完整信息",
|
|
||||||
field_length: "字段长度不能超过50个字符",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
}
|
}
|
@ -1,9 +1,6 @@
|
|||||||
<script setup>
|
<script setup>
|
||||||
import { NCarousel, NDivider, NMarquee, NPopselect } from "naive-ui";
|
import { NCarousel, NDivider, NMarquee, NPopselect } from "naive-ui";
|
||||||
import { onUnmounted, ref, watch, onMounted, computed } from "vue";
|
import { onUnmounted, ref, watch, onMounted, computed } from "vue";
|
||||||
import { useI18n } from "vue-i18n";
|
|
||||||
|
|
||||||
const { t } = useI18n();
|
|
||||||
|
|
||||||
function copyEmail() {
|
function copyEmail() {
|
||||||
navigator.clipboard.writeText("fiee@dlkadvisory.com");
|
navigator.clipboard.writeText("fiee@dlkadvisory.com");
|
||||||
@ -15,15 +12,15 @@ function copyEmail() {
|
|||||||
<!-- Title Section -->
|
<!-- Title Section -->
|
||||||
<div class="title-section">
|
<div class="title-section">
|
||||||
<div class="title-decoration"></div>
|
<div class="title-decoration"></div>
|
||||||
<div class="contact-title">{{ t("contacts.title") }}</div>
|
<div class="contact-title">Investor Contacts</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<!-- Card Section -->
|
<!-- Card Section -->
|
||||||
<div class="contact-card">
|
<div class="contact-card">
|
||||||
<div class="logo-text">{{ t("contacts.company_name") }}</div>
|
<div class="logo-text">FiEE Inc.</div>
|
||||||
<div class="relation-text">{{ t("contacts.investor_relations") }}</div>
|
<div class="relation-text">Investor Relations</div>
|
||||||
<div class="email-section">
|
<div class="email-section">
|
||||||
<span>{{ t("contacts.email_label") }}</span>
|
<span>Email:</span>
|
||||||
<span class="email-address" @click="copyEmail"
|
<span class="email-address" @click="copyEmail"
|
||||||
>fiee@dlkadvisory.com</span
|
>fiee@dlkadvisory.com</span
|
||||||
>
|
>
|
||||||
|
@ -1,9 +1,6 @@
|
|||||||
<script setup>
|
<script setup>
|
||||||
import { NCarousel, NDivider, NMarquee, NPopselect } from "naive-ui";
|
import { NCarousel, NDivider, NMarquee, NPopselect } from "naive-ui";
|
||||||
import { onUnmounted, ref, watch, onMounted, computed } from "vue";
|
import { onUnmounted, ref, watch, onMounted, computed } from "vue";
|
||||||
import { useI18n } from "vue-i18n";
|
|
||||||
|
|
||||||
const { t } = useI18n();
|
|
||||||
|
|
||||||
function copyEmail() {
|
function copyEmail() {
|
||||||
navigator.clipboard.writeText("fiee@dlkadvisory.com");
|
navigator.clipboard.writeText("fiee@dlkadvisory.com");
|
||||||
@ -15,15 +12,15 @@ function copyEmail() {
|
|||||||
<!-- Title Section -->
|
<!-- Title Section -->
|
||||||
<div class="title-section">
|
<div class="title-section">
|
||||||
<div class="title-decoration"></div>
|
<div class="title-decoration"></div>
|
||||||
<div class="contact-title">{{ t("contacts.title") }}</div>
|
<div class="contact-title">Investor Contacts</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<!-- Card Section -->
|
<!-- Card Section -->
|
||||||
<div class="contact-card">
|
<div class="contact-card">
|
||||||
<div class="logo-text">{{ t("contacts.company_name") }}</div>
|
<div class="logo-text">FiEE Inc.</div>
|
||||||
<div class="relation-text">{{ t("contacts.investor_relations") }}</div>
|
<div class="relation-text">Investor Relations</div>
|
||||||
<div class="email-section">
|
<div class="email-section">
|
||||||
<span>{{ t("contacts.email_label") }}</span>
|
<span>Email:</span>
|
||||||
<span class="email-address" @click="copyEmail"
|
<span class="email-address" @click="copyEmail"
|
||||||
>fiee@dlkadvisory.com</span
|
>fiee@dlkadvisory.com</span
|
||||||
>
|
>
|
||||||
|
@ -1,9 +1,6 @@
|
|||||||
<script setup>
|
<script setup>
|
||||||
import { NCarousel, NDivider, NMarquee, NPopselect } from "naive-ui";
|
import { NCarousel, NDivider, NMarquee, NPopselect } from "naive-ui";
|
||||||
import { onUnmounted, ref, watch, onMounted, computed } from "vue";
|
import { onUnmounted, ref, watch, onMounted, computed } from "vue";
|
||||||
import { useI18n } from "vue-i18n";
|
|
||||||
|
|
||||||
const { t } = useI18n();
|
|
||||||
|
|
||||||
function copyEmail() {
|
function copyEmail() {
|
||||||
navigator.clipboard.writeText("fiee@dlkadvisory.com");
|
navigator.clipboard.writeText("fiee@dlkadvisory.com");
|
||||||
@ -15,7 +12,7 @@ function copyEmail() {
|
|||||||
<!-- Title Section -->
|
<!-- Title Section -->
|
||||||
<div class="title-section">
|
<div class="title-section">
|
||||||
<div class="title-decoration"></div>
|
<div class="title-decoration"></div>
|
||||||
<div class="contact-title">{{ t("contacts.title") }}</div>
|
<div class="contact-title">Investor Contacts</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<!-- Card Section -->
|
<!-- Card Section -->
|
||||||
@ -25,10 +22,10 @@ function copyEmail() {
|
|||||||
src="@/assets/image/375/contacts-bg.png"
|
src="@/assets/image/375/contacts-bg.png"
|
||||||
alt=""
|
alt=""
|
||||||
/>
|
/>
|
||||||
<div class="logo-text">{{ t("contacts.company_name") }}</div>
|
<div class="logo-text">FiEE Inc.</div>
|
||||||
<div class="relation-text">{{ t("contacts.investor_relations") }}</div>
|
<div class="relation-text">Investor Relations</div>
|
||||||
<div class="email-section">
|
<div class="email-section">
|
||||||
<span>{{ t("contacts.email_label") }}</span>
|
<span>Email:</span>
|
||||||
<span class="email-address" @click="copyEmail"
|
<span class="email-address" @click="copyEmail"
|
||||||
>fiee@dlkadvisory.com</span
|
>fiee@dlkadvisory.com</span
|
||||||
>
|
>
|
||||||
|
@ -1,9 +1,6 @@
|
|||||||
<script setup>
|
<script setup>
|
||||||
import { NCarousel, NDivider, NMarquee, NPopselect } from "naive-ui";
|
import { NCarousel, NDivider, NMarquee, NPopselect } from "naive-ui";
|
||||||
import { onUnmounted, ref, watch, onMounted, computed } from "vue";
|
import { onUnmounted, ref, watch, onMounted, computed } from "vue";
|
||||||
import { useI18n } from "vue-i18n";
|
|
||||||
|
|
||||||
const { t } = useI18n();
|
|
||||||
|
|
||||||
function copyEmail() {
|
function copyEmail() {
|
||||||
navigator.clipboard.writeText("fiee@dlkadvisory.com");
|
navigator.clipboard.writeText("fiee@dlkadvisory.com");
|
||||||
@ -15,15 +12,15 @@ function copyEmail() {
|
|||||||
<!-- Title Section -->
|
<!-- Title Section -->
|
||||||
<div class="title-section">
|
<div class="title-section">
|
||||||
<div class="title-decoration"></div>
|
<div class="title-decoration"></div>
|
||||||
<div class="contact-title">{{ t("contacts.title") }}</div>
|
<div class="contact-title">Investor Contacts</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<!-- Card Section -->
|
<!-- Card Section -->
|
||||||
<div class="contact-card">
|
<div class="contact-card">
|
||||||
<div class="logo-text">{{ t("contacts.company_name") }}</div>
|
<div class="logo-text">FiEE Inc.</div>
|
||||||
<div class="relation-text">{{ t("contacts.investor_relations") }}</div>
|
<div class="relation-text">Investor Relations</div>
|
||||||
<div class="email-section">
|
<div class="email-section">
|
||||||
<span>{{ t("contacts.email_label") }}</span>
|
<span>Email:</span>
|
||||||
<span class="email-address" @click="copyEmail"
|
<span class="email-address" @click="copyEmail"
|
||||||
>fiee@dlkadvisory.com</span
|
>fiee@dlkadvisory.com</span
|
||||||
>
|
>
|
||||||
|
@ -1,11 +1,8 @@
|
|||||||
<script setup>
|
<script setup>
|
||||||
import { ref } from "vue";
|
import { ref } from "vue";
|
||||||
import { useI18n } from "vue-i18n";
|
|
||||||
|
|
||||||
import axios from "axios";
|
import axios from "axios";
|
||||||
import { message } from "@/utils/message.js";
|
import { message } from "@/utils/message.js";
|
||||||
|
|
||||||
const { t } = useI18n();
|
|
||||||
const form = ref({
|
const form = ref({
|
||||||
firstName: "",
|
firstName: "",
|
||||||
lastName: "",
|
lastName: "",
|
||||||
@ -20,11 +17,11 @@ async function handleSubmit(e) {
|
|||||||
if (
|
if (
|
||||||
Object.values(form.value).some((value) => value === "" || value === null)
|
Object.values(form.value).some((value) => value === "" || value === null)
|
||||||
) {
|
) {
|
||||||
message.warning(t("email_alerts.validation.complete_info"));
|
message.warning("请填写完整信息");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (Object.values(form.value).some((value) => value.length > 50)) {
|
if (Object.values(form.value).some((value) => value.length > 50)) {
|
||||||
message.warning(t("email_alerts.validation.field_length"));
|
message.warning("字段长度不能超过50个字符");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
let url = "http://114.218.158.24:9020/api/fiee/emailalerts/submit";
|
let url = "http://114.218.158.24:9020/api/fiee/emailalerts/submit";
|
||||||
@ -42,14 +39,14 @@ async function handleSubmit(e) {
|
|||||||
<!-- 未提交 -->
|
<!-- 未提交 -->
|
||||||
<div v-if="!submitted" class="title-section">
|
<div v-if="!submitted" class="title-section">
|
||||||
<div class="title-decoration"></div>
|
<div class="title-decoration"></div>
|
||||||
<div class="title">{{ t("email_alerts.title") }}</div>
|
<div class="title">E-Mail Alerts</div>
|
||||||
<div class="subtitle">{{ t("email_alerts.required_fields") }}</div>
|
<div class="subtitle">* Required Fields</div>
|
||||||
</div>
|
</div>
|
||||||
<!-- 已提交 -->
|
<!-- 已提交 -->
|
||||||
<div v-else class="title-section mt-[60px]">
|
<div v-else class="title-section mt-[60px]">
|
||||||
<div class="title-decoration"></div>
|
<div class="title-decoration"></div>
|
||||||
<div class="title">{{ t("email_alerts.submitted_successfully") }}</div>
|
<div class="title">Submitted successfully!</div>
|
||||||
<div class="subtitle">{{ t("email_alerts.submitted_info") }}</div>
|
<div class="subtitle">The information you submitted is as follows:</div>
|
||||||
</div>
|
</div>
|
||||||
<!-- Form Card -->
|
<!-- Form Card -->
|
||||||
<div
|
<div
|
||||||
@ -62,9 +59,7 @@ async function handleSubmit(e) {
|
|||||||
<template v-if="!submitted">
|
<template v-if="!submitted">
|
||||||
<form class="form-content" @submit="handleSubmit">
|
<form class="form-content" @submit="handleSubmit">
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label for="firstName">{{
|
<label for="firstName">* First Name</label>
|
||||||
t("email_alerts.form.first_name")
|
|
||||||
}}</label>
|
|
||||||
<input
|
<input
|
||||||
v-no-space
|
v-no-space
|
||||||
id="firstName"
|
id="firstName"
|
||||||
@ -74,7 +69,7 @@ async function handleSubmit(e) {
|
|||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label for="lastName">{{ t("email_alerts.form.last_name") }}</label>
|
<label for="lastName">* Last Name</label>
|
||||||
<input
|
<input
|
||||||
v-no-space
|
v-no-space
|
||||||
id="lastName"
|
id="lastName"
|
||||||
@ -84,7 +79,7 @@ async function handleSubmit(e) {
|
|||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label for="email">{{ t("email_alerts.form.email") }}</label>
|
<label for="email">* Email</label>
|
||||||
<input
|
<input
|
||||||
v-no-space
|
v-no-space
|
||||||
id="email"
|
id="email"
|
||||||
@ -94,7 +89,7 @@ async function handleSubmit(e) {
|
|||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label for="company">{{ t("email_alerts.form.company") }}</label>
|
<label for="company">* Company</label>
|
||||||
<input
|
<input
|
||||||
v-no-space
|
v-no-space
|
||||||
id="company"
|
id="company"
|
||||||
@ -104,7 +99,7 @@ async function handleSubmit(e) {
|
|||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label for="phone">{{ t("email_alerts.form.phone") }}</label>
|
<label for="phone">* Phone</label>
|
||||||
<input
|
<input
|
||||||
v-no-space
|
v-no-space
|
||||||
id="phone"
|
id="phone"
|
||||||
@ -113,53 +108,31 @@ async function handleSubmit(e) {
|
|||||||
required
|
required
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
<button type="submit" class="submit-btn">
|
<button type="submit" class="submit-btn">Submit</button>
|
||||||
{{ t("email_alerts.form.submit") }}
|
|
||||||
</button>
|
|
||||||
</form>
|
</form>
|
||||||
</template>
|
</template>
|
||||||
<template v-else>
|
<template v-else>
|
||||||
<div class="submitted-data">
|
<div class="submitted-data">
|
||||||
<div class="submitted-data-content">
|
<div class="submitted-data-content">
|
||||||
<div class="submitted-row">
|
<div class="submitted-row">
|
||||||
<span class="label">{{
|
<span class="label">First Name:</span>
|
||||||
t("email_alerts.submitted_data.first_name")
|
<span class="value">{{ form.firstName || "Not filled in" }}</span>
|
||||||
}}</span>
|
|
||||||
<span class="value">{{
|
|
||||||
form.firstName || t("email_alerts.submitted_data.not_filled")
|
|
||||||
}}</span>
|
|
||||||
</div>
|
</div>
|
||||||
<div class="submitted-row">
|
<div class="submitted-row">
|
||||||
<span class="label">{{
|
<span class="label">Last Name:</span>
|
||||||
t("email_alerts.submitted_data.last_name")
|
<span class="value">{{ form.lastName || "Not filled in" }}</span>
|
||||||
}}</span>
|
|
||||||
<span class="value">{{
|
|
||||||
form.lastName || t("email_alerts.submitted_data.not_filled")
|
|
||||||
}}</span>
|
|
||||||
</div>
|
</div>
|
||||||
<div class="submitted-row">
|
<div class="submitted-row">
|
||||||
<span class="label">{{
|
<span class="label">Email:</span>
|
||||||
t("email_alerts.submitted_data.email")
|
<span class="value">{{ form.email || "Not filled in" }}</span>
|
||||||
}}</span>
|
|
||||||
<span class="value">{{
|
|
||||||
form.email || t("email_alerts.submitted_data.not_filled")
|
|
||||||
}}</span>
|
|
||||||
</div>
|
</div>
|
||||||
<div class="submitted-row">
|
<div class="submitted-row">
|
||||||
<span class="label">{{
|
<span class="label">Company:</span>
|
||||||
t("email_alerts.submitted_data.company")
|
<span class="value">{{ form.company || "Not filled in" }}</span>
|
||||||
}}</span>
|
|
||||||
<span class="value">{{
|
|
||||||
form.company || t("email_alerts.submitted_data.not_filled")
|
|
||||||
}}</span>
|
|
||||||
</div>
|
</div>
|
||||||
<div class="submitted-row">
|
<div class="submitted-row">
|
||||||
<span class="label">{{
|
<span class="label">Phone:</span>
|
||||||
t("email_alerts.submitted_data.phone")
|
<span class="value">{{ form.phone || "Not filled in" }}</span>
|
||||||
}}</span>
|
|
||||||
<span class="value">{{
|
|
||||||
form.phone || t("email_alerts.submitted_data.not_filled")
|
|
||||||
}}</span>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -1,11 +1,8 @@
|
|||||||
<script setup>
|
<script setup>
|
||||||
import { ref } from "vue";
|
import { ref } from "vue";
|
||||||
import { useI18n } from "vue-i18n";
|
|
||||||
|
|
||||||
import axios from "axios";
|
import axios from "axios";
|
||||||
import { message } from "@/utils/message.js";
|
import { message } from "@/utils/message.js";
|
||||||
|
|
||||||
const { t } = useI18n();
|
|
||||||
const form = ref({
|
const form = ref({
|
||||||
firstName: "",
|
firstName: "",
|
||||||
lastName: "",
|
lastName: "",
|
||||||
@ -20,11 +17,11 @@ async function handleSubmit(e) {
|
|||||||
if (
|
if (
|
||||||
Object.values(form.value).some((value) => value === "" || value === null)
|
Object.values(form.value).some((value) => value === "" || value === null)
|
||||||
) {
|
) {
|
||||||
message.warning(t("email_alerts.validation.complete_info"));
|
message.warning("请填写完整信息");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (Object.values(form.value).some((value) => value.length > 50)) {
|
if (Object.values(form.value).some((value) => value.length > 50)) {
|
||||||
message.warning(t("email_alerts.validation.field_length"));
|
message.warning("字段长度不能超过50个字符");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
let url = "http://114.218.158.24:9020/api/fiee/emailalerts/submit";
|
let url = "http://114.218.158.24:9020/api/fiee/emailalerts/submit";
|
||||||
@ -42,14 +39,14 @@ async function handleSubmit(e) {
|
|||||||
<!-- 未提交 -->
|
<!-- 未提交 -->
|
||||||
<div v-if="!submitted" class="title-section">
|
<div v-if="!submitted" class="title-section">
|
||||||
<div class="title-decoration"></div>
|
<div class="title-decoration"></div>
|
||||||
<div class="title">{{ t("email_alerts.title") }}</div>
|
<div class="title">E-Mail Alerts</div>
|
||||||
<div class="subtitle">{{ t("email_alerts.required_fields") }}</div>
|
<div class="subtitle">* Required Fields</div>
|
||||||
</div>
|
</div>
|
||||||
<!-- 已提交 -->
|
<!-- 已提交 -->
|
||||||
<div v-else class="title-section">
|
<div v-else class="title-section">
|
||||||
<div class="title-decoration"></div>
|
<div class="title-decoration"></div>
|
||||||
<div class="title">{{ t("email_alerts.submitted_successfully") }}</div>
|
<div class="title">Submitted successfully!</div>
|
||||||
<div class="subtitle">{{ t("email_alerts.submitted_info") }}</div>
|
<div class="subtitle">The information you submitted is as follows:</div>
|
||||||
</div>
|
</div>
|
||||||
<!-- Form Card -->
|
<!-- Form Card -->
|
||||||
<div
|
<div
|
||||||
@ -62,9 +59,7 @@ async function handleSubmit(e) {
|
|||||||
<template v-if="!submitted">
|
<template v-if="!submitted">
|
||||||
<form class="form-content" @submit="handleSubmit">
|
<form class="form-content" @submit="handleSubmit">
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label for="firstName">{{
|
<label for="firstName">* First Name</label>
|
||||||
t("email_alerts.form.first_name")
|
|
||||||
}}</label>
|
|
||||||
<input
|
<input
|
||||||
id="firstName"
|
id="firstName"
|
||||||
v-no-space
|
v-no-space
|
||||||
@ -74,7 +69,7 @@ async function handleSubmit(e) {
|
|||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label for="lastName">{{ t("email_alerts.form.last_name") }}</label>
|
<label for="lastName">* Last Name</label>
|
||||||
<input
|
<input
|
||||||
id="lastName"
|
id="lastName"
|
||||||
v-no-space
|
v-no-space
|
||||||
@ -84,7 +79,7 @@ async function handleSubmit(e) {
|
|||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label for="email">{{ t("email_alerts.form.email") }}</label>
|
<label for="email">* Email</label>
|
||||||
<input
|
<input
|
||||||
id="email"
|
id="email"
|
||||||
v-no-space
|
v-no-space
|
||||||
@ -94,7 +89,7 @@ async function handleSubmit(e) {
|
|||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label for="company">{{ t("email_alerts.form.company") }}</label>
|
<label for="company">* Company</label>
|
||||||
<input
|
<input
|
||||||
id="company"
|
id="company"
|
||||||
v-no-space
|
v-no-space
|
||||||
@ -104,56 +99,34 @@ async function handleSubmit(e) {
|
|||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label for="phone">{{ t("email_alerts.form.phone") }}</label>
|
<label for="phone">* Phone</label>
|
||||||
<input id="phone" v-no-space v-model="form.phone" type="tel" />
|
<input id="phone" v-no-space v-model="form.phone" type="tel" />
|
||||||
</div>
|
</div>
|
||||||
<button type="submit" class="submit-btn">
|
<button type="submit" class="submit-btn">Submit</button>
|
||||||
{{ t("email_alerts.form.submit") }}
|
|
||||||
</button>
|
|
||||||
</form>
|
</form>
|
||||||
</template>
|
</template>
|
||||||
<template v-else>
|
<template v-else>
|
||||||
<div class="submitted-data">
|
<div class="submitted-data">
|
||||||
<div class="submitted-data-content">
|
<div class="submitted-data-content">
|
||||||
<div class="submitted-row">
|
<div class="submitted-row">
|
||||||
<span class="label">{{
|
<span class="label">First Name:</span>
|
||||||
t("email_alerts.submitted_data.first_name")
|
<span class="value">{{ form.firstName || "Not filled in" }}</span>
|
||||||
}}</span>
|
|
||||||
<span class="value">{{
|
|
||||||
form.firstName || t("email_alerts.submitted_data.not_filled")
|
|
||||||
}}</span>
|
|
||||||
</div>
|
</div>
|
||||||
<div class="submitted-row">
|
<div class="submitted-row">
|
||||||
<span class="label">{{
|
<span class="label">Last Name:</span>
|
||||||
t("email_alerts.submitted_data.last_name")
|
<span class="value">{{ form.lastName || "Not filled in" }}</span>
|
||||||
}}</span>
|
|
||||||
<span class="value">{{
|
|
||||||
form.lastName || t("email_alerts.submitted_data.not_filled")
|
|
||||||
}}</span>
|
|
||||||
</div>
|
</div>
|
||||||
<div class="submitted-row">
|
<div class="submitted-row">
|
||||||
<span class="label">{{
|
<span class="label">Email:</span>
|
||||||
t("email_alerts.submitted_data.email")
|
<span class="value">{{ form.email || "Not filled in" }}</span>
|
||||||
}}</span>
|
|
||||||
<span class="value">{{
|
|
||||||
form.email || t("email_alerts.submitted_data.not_filled")
|
|
||||||
}}</span>
|
|
||||||
</div>
|
</div>
|
||||||
<div class="submitted-row">
|
<div class="submitted-row">
|
||||||
<span class="label">{{
|
<span class="label">Company:</span>
|
||||||
t("email_alerts.submitted_data.company")
|
<span class="value">{{ form.company || "Not filled in" }}</span>
|
||||||
}}</span>
|
|
||||||
<span class="value">{{
|
|
||||||
form.company || t("email_alerts.submitted_data.not_filled")
|
|
||||||
}}</span>
|
|
||||||
</div>
|
</div>
|
||||||
<div class="submitted-row">
|
<div class="submitted-row">
|
||||||
<span class="label">{{
|
<span class="label">Phone:</span>
|
||||||
t("email_alerts.submitted_data.phone")
|
<span class="value">{{ form.phone || "Not filled in" }}</span>
|
||||||
}}</span>
|
|
||||||
<span class="value">{{
|
|
||||||
form.phone || t("email_alerts.submitted_data.not_filled")
|
|
||||||
}}</span>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -1,10 +1,7 @@
|
|||||||
<script setup>
|
<script setup>
|
||||||
import { ref } from "vue";
|
import { ref } from "vue";
|
||||||
import { useI18n } from "vue-i18n";
|
|
||||||
import axios from "axios";
|
import axios from "axios";
|
||||||
import { message } from "@/utils/message.js";
|
import { message } from "@/utils/message.js";
|
||||||
|
|
||||||
const { t } = useI18n();
|
|
||||||
const form = ref({
|
const form = ref({
|
||||||
firstName: "",
|
firstName: "",
|
||||||
lastName: "",
|
lastName: "",
|
||||||
@ -20,11 +17,11 @@ async function handleSubmit(e) {
|
|||||||
if (
|
if (
|
||||||
Object.values(form.value).some((value) => value === "" || value === null)
|
Object.values(form.value).some((value) => value === "" || value === null)
|
||||||
) {
|
) {
|
||||||
message.warning(t("email_alerts.validation.complete_info"));
|
message.warning("请填写完整信息");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (Object.values(form.value).some((value) => value.length > 50)) {
|
if (Object.values(form.value).some((value) => value.length > 50)) {
|
||||||
message.warning(t("email_alerts.validation.field_length"));
|
message.warning("字段长度不能超过50个字符");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
let url = "http://114.218.158.24:9020/api/fiee/emailalerts/submit";
|
let url = "http://114.218.158.24:9020/api/fiee/emailalerts/submit";
|
||||||
@ -42,35 +39,33 @@ async function handleSubmit(e) {
|
|||||||
<template v-if="!submitted">
|
<template v-if="!submitted">
|
||||||
<div class="title-block">
|
<div class="title-block">
|
||||||
<div class="title-bar"></div>
|
<div class="title-bar"></div>
|
||||||
<h2 class="title">{{ t("email_alerts.title") }}</h2>
|
<h2 class="title">E-Mail Alerts</h2>
|
||||||
<p class="subtitle">{{ t("email_alerts.required_fields") }}</p>
|
<p class="subtitle">* Required Fields</p>
|
||||||
</div>
|
</div>
|
||||||
<!-- Card -->
|
<!-- Card -->
|
||||||
<div class="card">
|
<div class="card">
|
||||||
<form class="form" @submit="handleSubmit">
|
<form class="form" @submit="handleSubmit">
|
||||||
<div class="form-field">
|
<div class="form-field">
|
||||||
<label>{{ t("email_alerts.form.first_name") }}</label>
|
<label>* First Name</label>
|
||||||
<input v-no-space v-model="form.firstName" type="text" />
|
<input v-no-space v-model="form.firstName" type="text" />
|
||||||
</div>
|
</div>
|
||||||
<div class="form-field">
|
<div class="form-field">
|
||||||
<label>{{ t("email_alerts.form.last_name") }}</label>
|
<label>* Last Name</label>
|
||||||
<input v-no-space v-model="form.lastName" type="text" />
|
<input v-no-space v-model="form.lastName" type="text" />
|
||||||
</div>
|
</div>
|
||||||
<div class="form-field">
|
<div class="form-field">
|
||||||
<label>{{ t("email_alerts.form.email") }}</label>
|
<label>* Email</label>
|
||||||
<input v-no-space v-model="form.email" type="email" />
|
<input v-no-space v-model="form.email" type="email" />
|
||||||
</div>
|
</div>
|
||||||
<div class="form-field">
|
<div class="form-field">
|
||||||
<label>{{ t("email_alerts.form.company") }}</label>
|
<label>* Company</label>
|
||||||
<input v-no-space v-model="form.company" type="text" />
|
<input v-no-space v-model="form.company" type="text" />
|
||||||
</div>
|
</div>
|
||||||
<div class="form-field">
|
<div class="form-field">
|
||||||
<label>{{ t("email_alerts.form.phone") }}</label>
|
<label>* Phone</label>
|
||||||
<input v-no-space v-model="form.phone" type="tel" />
|
<input v-no-space v-model="form.phone" type="tel" />
|
||||||
</div>
|
</div>
|
||||||
<button type="submit" class="submit">
|
<button type="submit" class="submit">Submit</button>
|
||||||
{{ t("email_alerts.form.submit") }}
|
|
||||||
</button>
|
|
||||||
</form>
|
</form>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
@ -78,40 +73,30 @@ async function handleSubmit(e) {
|
|||||||
<div class="success-block">
|
<div class="success-block">
|
||||||
<div class="title-block">
|
<div class="title-block">
|
||||||
<div class="title-bar"></div>
|
<div class="title-bar"></div>
|
||||||
<h2 class="title">{{ t("email_alerts.submitted_successfully") }}</h2>
|
<h2 class="title">Submitted successfully!</h2>
|
||||||
<p class="subtitle">{{ t("email_alerts.submitted_info") }}</p>
|
<p class="subtitle">The information you submitted is as follows:</p>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="success-card">
|
<div class="success-card">
|
||||||
<div class="success-card-item">
|
<div class="success-card-item">
|
||||||
<div class="font-semibold success-card-label">
|
<div class="font-semibold success-card-label">First Name:</div>
|
||||||
{{ t("email_alerts.submitted_data.first_name") }}
|
{{ form.firstName || "Not filled in" }}
|
||||||
</div>
|
|
||||||
{{ form.firstName || t("email_alerts.submitted_data.not_filled") }}
|
|
||||||
</div>
|
</div>
|
||||||
<div class="success-card-item">
|
<div class="success-card-item">
|
||||||
<div class="font-semibold success-card-label">
|
<div class="font-semibold success-card-label">Last Name:</div>
|
||||||
{{ t("email_alerts.submitted_data.last_name") }}
|
{{ form.lastName || "Not filled in" }}
|
||||||
</div>
|
|
||||||
{{ form.lastName || t("email_alerts.submitted_data.not_filled") }}
|
|
||||||
</div>
|
</div>
|
||||||
<div class="success-card-item">
|
<div class="success-card-item">
|
||||||
<div class="font-semibold success-card-label">
|
<div class="font-semibold success-card-label">Email:</div>
|
||||||
{{ t("email_alerts.submitted_data.email") }}
|
{{ form.email || "Not filled in" }}
|
||||||
</div>
|
|
||||||
{{ form.email || t("email_alerts.submitted_data.not_filled") }}
|
|
||||||
</div>
|
</div>
|
||||||
<div class="success-card-item">
|
<div class="success-card-item">
|
||||||
<div class="font-semibold success-card-label">
|
<div class="font-semibold success-card-label">Company:</div>
|
||||||
{{ t("email_alerts.submitted_data.company") }}
|
{{ form.company || "Not filled in" }}
|
||||||
</div>
|
|
||||||
{{ form.company || t("email_alerts.submitted_data.not_filled") }}
|
|
||||||
</div>
|
</div>
|
||||||
<div class="success-card-item">
|
<div class="success-card-item">
|
||||||
<div class="font-semibold success-card-label">
|
<div class="font-semibold success-card-label">Phone:</div>
|
||||||
{{ t("email_alerts.submitted_data.phone") }}
|
{{ form.phone || "Not filled in" }}
|
||||||
</div>
|
|
||||||
{{ form.phone || t("email_alerts.submitted_data.not_filled") }}
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="submitted-bg"></div>
|
<div class="submitted-bg"></div>
|
||||||
|
@ -1,11 +1,8 @@
|
|||||||
<script setup>
|
<script setup>
|
||||||
import { ref } from "vue";
|
import { ref } from "vue";
|
||||||
import { useI18n } from "vue-i18n";
|
|
||||||
|
|
||||||
import axios from "axios";
|
import axios from "axios";
|
||||||
import { message } from "@/utils/message.js";
|
import { message } from "@/utils/message.js";
|
||||||
|
|
||||||
const { t } = useI18n();
|
|
||||||
const form = ref({
|
const form = ref({
|
||||||
firstName: "",
|
firstName: "",
|
||||||
lastName: "",
|
lastName: "",
|
||||||
@ -20,11 +17,11 @@ async function handleSubmit(e) {
|
|||||||
if (
|
if (
|
||||||
Object.values(form.value).some((value) => value === "" || value === null)
|
Object.values(form.value).some((value) => value === "" || value === null)
|
||||||
) {
|
) {
|
||||||
message.warning(t("email_alerts.validation.complete_info"));
|
message.warning("请填写完整信息");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (Object.values(form.value).some((value) => value.length > 50)) {
|
if (Object.values(form.value).some((value) => value.length > 50)) {
|
||||||
message.warning(t("email_alerts.validation.field_length"));
|
message.warning("字段长度不能超过50个字符");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
let url = "http://114.218.158.24:9020/api/fiee/emailalerts/submit";
|
let url = "http://114.218.158.24:9020/api/fiee/emailalerts/submit";
|
||||||
@ -42,14 +39,14 @@ async function handleSubmit(e) {
|
|||||||
<!-- 未提交 -->
|
<!-- 未提交 -->
|
||||||
<div v-if="!submitted" class="title-section">
|
<div v-if="!submitted" class="title-section">
|
||||||
<div class="title-decoration"></div>
|
<div class="title-decoration"></div>
|
||||||
<div class="title">{{ t("email_alerts.title") }}</div>
|
<div class="title">E-Mail Alerts</div>
|
||||||
<div class="subtitle">{{ t("email_alerts.required_fields") }}</div>
|
<div class="subtitle">* Required Fields</div>
|
||||||
</div>
|
</div>
|
||||||
<!-- 已提交 -->
|
<!-- 已提交 -->
|
||||||
<div v-else class="title-section">
|
<div v-else class="title-section">
|
||||||
<div class="title-decoration"></div>
|
<div class="title-decoration"></div>
|
||||||
<div class="title">{{ t("email_alerts.submitted_successfully") }}</div>
|
<div class="title">Submitted successfully!</div>
|
||||||
<div class="subtitle">{{ t("email_alerts.submitted_info") }}</div>
|
<div class="subtitle">The information you submitted is as follows:</div>
|
||||||
</div>
|
</div>
|
||||||
<!-- Form Card -->
|
<!-- Form Card -->
|
||||||
<div
|
<div
|
||||||
@ -62,9 +59,7 @@ async function handleSubmit(e) {
|
|||||||
<template v-if="!submitted">
|
<template v-if="!submitted">
|
||||||
<form class="form-content" @submit="handleSubmit">
|
<form class="form-content" @submit="handleSubmit">
|
||||||
<div class="form-group mt-[36px]">
|
<div class="form-group mt-[36px]">
|
||||||
<label for="firstName">{{
|
<label for="firstName">* First Name</label>
|
||||||
t("email_alerts.form.first_name")
|
|
||||||
}}</label>
|
|
||||||
<input
|
<input
|
||||||
id="firstName"
|
id="firstName"
|
||||||
v-no-space
|
v-no-space
|
||||||
@ -74,7 +69,7 @@ async function handleSubmit(e) {
|
|||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label for="lastName">{{ t("email_alerts.form.last_name") }}</label>
|
<label for="lastName">* Last Name</label>
|
||||||
<input
|
<input
|
||||||
id="lastName"
|
id="lastName"
|
||||||
v-no-space
|
v-no-space
|
||||||
@ -84,7 +79,7 @@ async function handleSubmit(e) {
|
|||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label for="email">{{ t("email_alerts.form.email") }}</label>
|
<label for="email">* Email</label>
|
||||||
<input
|
<input
|
||||||
id="email"
|
id="email"
|
||||||
v-no-space
|
v-no-space
|
||||||
@ -94,7 +89,7 @@ async function handleSubmit(e) {
|
|||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label for="company">{{ t("email_alerts.form.company") }}</label>
|
<label for="company">* Company</label>
|
||||||
<input
|
<input
|
||||||
id="company"
|
id="company"
|
||||||
v-no-space
|
v-no-space
|
||||||
@ -104,56 +99,34 @@ async function handleSubmit(e) {
|
|||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label for="phone">{{ t("email_alerts.form.phone") }}</label>
|
<label for="phone">* Phone</label>
|
||||||
<input id="phone" v-no-space v-model="form.phone" type="tel" />
|
<input id="phone" v-no-space v-model="form.phone" type="tel" />
|
||||||
</div>
|
</div>
|
||||||
<button type="submit" class="submit-btn">
|
<button type="submit" class="submit-btn">Submit</button>
|
||||||
{{ t("email_alerts.form.submit") }}
|
|
||||||
</button>
|
|
||||||
</form>
|
</form>
|
||||||
</template>
|
</template>
|
||||||
<template v-else>
|
<template v-else>
|
||||||
<div class="submitted-data">
|
<div class="submitted-data">
|
||||||
<div class="submitted-data-content">
|
<div class="submitted-data-content">
|
||||||
<div class="submitted-row">
|
<div class="submitted-row">
|
||||||
<span class="label">{{
|
<span class="label">First Name:</span>
|
||||||
t("email_alerts.submitted_data.first_name")
|
<span class="value">{{ form.firstName || "Not filled in" }}</span>
|
||||||
}}</span>
|
|
||||||
<span class="value">{{
|
|
||||||
form.firstName || t("email_alerts.submitted_data.not_filled")
|
|
||||||
}}</span>
|
|
||||||
</div>
|
</div>
|
||||||
<div class="submitted-row">
|
<div class="submitted-row">
|
||||||
<span class="label">{{
|
<span class="label">Last Name:</span>
|
||||||
t("email_alerts.submitted_data.last_name")
|
<span class="value">{{ form.lastName || "Not filled in" }}</span>
|
||||||
}}</span>
|
|
||||||
<span class="value">{{
|
|
||||||
form.lastName || t("email_alerts.submitted_data.not_filled")
|
|
||||||
}}</span>
|
|
||||||
</div>
|
</div>
|
||||||
<div class="submitted-row">
|
<div class="submitted-row">
|
||||||
<span class="label">{{
|
<span class="label">Email:</span>
|
||||||
t("email_alerts.submitted_data.email")
|
<span class="value">{{ form.email || "Not filled in" }}</span>
|
||||||
}}</span>
|
|
||||||
<span class="value">{{
|
|
||||||
form.email || t("email_alerts.submitted_data.not_filled")
|
|
||||||
}}</span>
|
|
||||||
</div>
|
</div>
|
||||||
<div class="submitted-row">
|
<div class="submitted-row">
|
||||||
<span class="label">{{
|
<span class="label">Company:</span>
|
||||||
t("email_alerts.submitted_data.company")
|
<span class="value">{{ form.company || "Not filled in" }}</span>
|
||||||
}}</span>
|
|
||||||
<span class="value">{{
|
|
||||||
form.company || t("email_alerts.submitted_data.not_filled")
|
|
||||||
}}</span>
|
|
||||||
</div>
|
</div>
|
||||||
<div class="submitted-row">
|
<div class="submitted-row">
|
||||||
<span class="label">{{
|
<span class="label">Phone:</span>
|
||||||
t("email_alerts.submitted_data.phone")
|
<span class="value">{{ form.phone || "Not filled in" }}</span>
|
||||||
}}</span>
|
|
||||||
<span class="value">{{
|
|
||||||
form.phone || t("email_alerts.submitted_data.not_filled")
|
|
||||||
}}</span>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -588,8 +588,6 @@ const getPageData = async () => {
|
|||||||
padding: 0 16px;
|
padding: 0 16px;
|
||||||
margin-bottom: 32px;
|
margin-bottom: 32px;
|
||||||
margin-top: 32px;
|
margin-top: 32px;
|
||||||
flex-wrap: wrap;
|
|
||||||
gap: 10px;
|
|
||||||
|
|
||||||
.range-label {
|
.range-label {
|
||||||
font-family: "PingFang SC", sans-serif;
|
font-family: "PingFang SC", sans-serif;
|
||||||
|
@ -587,8 +587,6 @@ const getPageData = async () => {
|
|||||||
padding: 0 16px;
|
padding: 0 16px;
|
||||||
margin-bottom: 32px;
|
margin-bottom: 32px;
|
||||||
margin-top: 32px;
|
margin-top: 32px;
|
||||||
flex-wrap: wrap;
|
|
||||||
gap: 10px;
|
|
||||||
|
|
||||||
.range-label {
|
.range-label {
|
||||||
font-family: "PingFang SC", sans-serif;
|
font-family: "PingFang SC", sans-serif;
|
||||||
|
@ -560,8 +560,6 @@ const getPageData = async () => {
|
|||||||
gap: 8 * 5.12px;
|
gap: 8 * 5.12px;
|
||||||
padding: 0 16 * 5.12px;
|
padding: 0 16 * 5.12px;
|
||||||
margin-bottom: 32 * 5.12px;
|
margin-bottom: 32 * 5.12px;
|
||||||
flex-wrap: wrap;
|
|
||||||
gap: 10 * 5.12px;
|
|
||||||
|
|
||||||
.range-label {
|
.range-label {
|
||||||
font-family: "PingFang SC", sans-serif;
|
font-family: "PingFang SC", sans-serif;
|
||||||
|
@ -589,8 +589,6 @@ const getPageData = async () => {
|
|||||||
padding: 0 16 * 2.5px;
|
padding: 0 16 * 2.5px;
|
||||||
margin-bottom: 32 * 2.5px;
|
margin-bottom: 32 * 2.5px;
|
||||||
margin-top: 32 * 2.5px;
|
margin-top: 32 * 2.5px;
|
||||||
flex-wrap: wrap;
|
|
||||||
gap: 10 * 2.5px;
|
|
||||||
|
|
||||||
.range-label {
|
.range-label {
|
||||||
font-family: "PingFang SC", sans-serif;
|
font-family: "PingFang SC", sans-serif;
|
||||||
|
@ -8,9 +8,9 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="search-container">
|
<div class="search-container">
|
||||||
<custom-select
|
<n-select
|
||||||
:options="state.selectOptions"
|
:options="state.selectOptions"
|
||||||
v-model="state.selectedValue"
|
v-model:value="state.selectedValue"
|
||||||
class="search-select"
|
class="search-select"
|
||||||
/>
|
/>
|
||||||
<input
|
<input
|
||||||
@ -191,7 +191,6 @@
|
|||||||
|
|
||||||
<script setup>
|
<script setup>
|
||||||
import customDefaultPage from "@/components/customDefaultPage/index.vue";
|
import customDefaultPage from "@/components/customDefaultPage/index.vue";
|
||||||
import customSelect from "@/components/customSelect/index.vue";
|
|
||||||
import {
|
import {
|
||||||
reactive,
|
reactive,
|
||||||
onMounted,
|
onMounted,
|
||||||
@ -201,7 +200,7 @@ import {
|
|||||||
computed,
|
computed,
|
||||||
onUnmounted,
|
onUnmounted,
|
||||||
} from "vue";
|
} from "vue";
|
||||||
import { NTooltip } from "naive-ui";
|
import { NSelect, NInput, NButton, NTooltip } from "naive-ui";
|
||||||
import { useI18n } from "vue-i18n";
|
import { useI18n } from "vue-i18n";
|
||||||
import axios from "axios";
|
import axios from "axios";
|
||||||
|
|
||||||
@ -481,7 +480,7 @@ const handleClickOutside = (event) => {
|
|||||||
.search-input {
|
.search-input {
|
||||||
flex: 1;
|
flex: 1;
|
||||||
height: 46px;
|
height: 46px;
|
||||||
padding: 7px 12px;
|
padding: 7px;
|
||||||
border: 1px solid #e0e0e6;
|
border: 1px solid #e0e0e6;
|
||||||
border-radius: 3px;
|
border-radius: 3px;
|
||||||
font-family: "PingFang SC", sans-serif;
|
font-family: "PingFang SC", sans-serif;
|
||||||
@ -490,13 +489,32 @@ const handleClickOutside = (event) => {
|
|||||||
line-height: 1.375em;
|
line-height: 1.375em;
|
||||||
letter-spacing: 0.03em;
|
letter-spacing: 0.03em;
|
||||||
color: #455363;
|
color: #455363;
|
||||||
box-sizing: border-box;
|
|
||||||
|
|
||||||
&::placeholder {
|
&::placeholder {
|
||||||
color: #b6b6b6;
|
color: #b6b6b6;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
:deep(.n-input) {
|
||||||
|
.n-input__input {
|
||||||
|
padding: 4px 0;
|
||||||
|
// border: 1px solid #ccc;
|
||||||
|
border-radius: 4px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
:deep(.n-select) {
|
||||||
|
.n-select__input {
|
||||||
|
padding: 8px 12px;
|
||||||
|
border: 1px solid #ccc;
|
||||||
|
border-radius: 4px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
:deep(.n-button) {
|
||||||
|
padding: 20px 16px;
|
||||||
|
border-radius: 4px;
|
||||||
|
}
|
||||||
.search-button {
|
.search-button {
|
||||||
height: 46px;
|
height: 46px;
|
||||||
padding: 7px 12px;
|
padding: 7px 12px;
|
||||||
@ -511,7 +529,6 @@ const handleClickOutside = (event) => {
|
|||||||
font-size: 16px;
|
font-size: 16px;
|
||||||
line-height: 1.375em;
|
line-height: 1.375em;
|
||||||
letter-spacing: 0.03em;
|
letter-spacing: 0.03em;
|
||||||
box-sizing: border-box;
|
|
||||||
&:hover {
|
&:hover {
|
||||||
background: #ff7bac;
|
background: #ff7bac;
|
||||||
color: #fff;
|
color: #fff;
|
||||||
|
@ -8,9 +8,9 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="search-container">
|
<div class="search-container">
|
||||||
<custom-select
|
<n-select
|
||||||
:options="state.selectOptions"
|
:options="state.selectOptions"
|
||||||
v-model="state.selectedValue"
|
v-model:value="state.selectedValue"
|
||||||
class="search-select"
|
class="search-select"
|
||||||
/>
|
/>
|
||||||
<input
|
<input
|
||||||
@ -191,7 +191,6 @@
|
|||||||
|
|
||||||
<script setup>
|
<script setup>
|
||||||
import customDefaultPage from "@/components/customDefaultPage/index.vue";
|
import customDefaultPage from "@/components/customDefaultPage/index.vue";
|
||||||
import customSelect from "@/components/customSelect/index.vue";
|
|
||||||
import {
|
import {
|
||||||
reactive,
|
reactive,
|
||||||
onMounted,
|
onMounted,
|
||||||
@ -201,7 +200,7 @@ import {
|
|||||||
computed,
|
computed,
|
||||||
onUnmounted,
|
onUnmounted,
|
||||||
} from "vue";
|
} from "vue";
|
||||||
import { NTooltip } from "naive-ui";
|
import { NSelect, NInput, NButton, NTooltip } from "naive-ui";
|
||||||
import { useI18n } from "vue-i18n";
|
import { useI18n } from "vue-i18n";
|
||||||
import axios from "axios";
|
import axios from "axios";
|
||||||
|
|
||||||
@ -471,6 +470,7 @@ const handleClickOutside = (event) => {
|
|||||||
|
|
||||||
.search-select {
|
.search-select {
|
||||||
width: 201px;
|
width: 201px;
|
||||||
|
height: 34px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.search-input {
|
.search-input {
|
||||||
@ -485,13 +485,32 @@ const handleClickOutside = (event) => {
|
|||||||
line-height: 1.375em;
|
line-height: 1.375em;
|
||||||
letter-spacing: 3%;
|
letter-spacing: 3%;
|
||||||
color: #455363;
|
color: #455363;
|
||||||
box-sizing: border-box;
|
|
||||||
|
|
||||||
&::placeholder {
|
&::placeholder {
|
||||||
color: #b6b6b6;
|
color: #b6b6b6;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
:deep(.n-input) {
|
||||||
|
.n-input__input {
|
||||||
|
padding: 4px 0;
|
||||||
|
// border: 1px solid #ccc;
|
||||||
|
border-radius: 4px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
:deep(.n-select) {
|
||||||
|
.n-select__input {
|
||||||
|
padding: 8px 12px;
|
||||||
|
border: 1px solid #ccc;
|
||||||
|
border-radius: 4px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
:deep(.n-button) {
|
||||||
|
padding: 20px 16px;
|
||||||
|
border-radius: 4px;
|
||||||
|
}
|
||||||
.search-button {
|
.search-button {
|
||||||
height: 34px;
|
height: 34px;
|
||||||
padding: 7px 12px;
|
padding: 7px 12px;
|
||||||
@ -506,7 +525,6 @@ const handleClickOutside = (event) => {
|
|||||||
font-size: 16px;
|
font-size: 16px;
|
||||||
line-height: 1.375em;
|
line-height: 1.375em;
|
||||||
letter-spacing: 3%;
|
letter-spacing: 3%;
|
||||||
box-sizing: border-box;
|
|
||||||
&:hover {
|
&:hover {
|
||||||
background: #ff7bac;
|
background: #ff7bac;
|
||||||
color: #fff;
|
color: #fff;
|
||||||
|
@ -8,9 +8,9 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="search-container">
|
<div class="search-container">
|
||||||
<custom-select
|
<n-select
|
||||||
:options="state.selectOptions"
|
:options="state.selectOptions"
|
||||||
v-model="state.selectedValue"
|
v-model:value="state.selectedValue"
|
||||||
class="search-select"
|
class="search-select"
|
||||||
/>
|
/>
|
||||||
<input
|
<input
|
||||||
@ -191,7 +191,6 @@
|
|||||||
|
|
||||||
<script setup>
|
<script setup>
|
||||||
import customDefaultPage from "@/components/customDefaultPage/index.vue";
|
import customDefaultPage from "@/components/customDefaultPage/index.vue";
|
||||||
import customSelect from "@/components/customSelect/index.vue";
|
|
||||||
import {
|
import {
|
||||||
reactive,
|
reactive,
|
||||||
onMounted,
|
onMounted,
|
||||||
@ -201,7 +200,7 @@ import {
|
|||||||
computed,
|
computed,
|
||||||
onUnmounted,
|
onUnmounted,
|
||||||
} from "vue";
|
} from "vue";
|
||||||
import { NTooltip } from "naive-ui";
|
import { NSelect, NInput, NButton, NTooltip } from "naive-ui";
|
||||||
import { useI18n } from "vue-i18n";
|
import { useI18n } from "vue-i18n";
|
||||||
import axios from "axios";
|
import axios from "axios";
|
||||||
|
|
||||||
@ -471,6 +470,7 @@ const handleClickOutside = (event) => {
|
|||||||
|
|
||||||
.search-select {
|
.search-select {
|
||||||
width: 134 * 2.5px;
|
width: 134 * 2.5px;
|
||||||
|
height: 34 * 2.5px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.search-input {
|
.search-input {
|
||||||
@ -485,13 +485,32 @@ const handleClickOutside = (event) => {
|
|||||||
line-height: 1.375em;
|
line-height: 1.375em;
|
||||||
letter-spacing: 0.48 * 2.5px;
|
letter-spacing: 0.48 * 2.5px;
|
||||||
color: #455363;
|
color: #455363;
|
||||||
box-sizing: border-box;
|
|
||||||
|
|
||||||
&::placeholder {
|
&::placeholder {
|
||||||
color: #b6b6b6;
|
color: #b6b6b6;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
:deep(.n-input) {
|
||||||
|
.n-input__input {
|
||||||
|
padding: 4 * 2.5px 0;
|
||||||
|
// border: 1*2.5px solid #ccc;
|
||||||
|
border-radius: 4 * 2.5px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
:deep(.n-select) {
|
||||||
|
.n-select__input {
|
||||||
|
padding: 8 * 2.5px 12 * 2.5px;
|
||||||
|
border: 1 * 2.5px solid #ccc;
|
||||||
|
border-radius: 4 * 2.5px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
:deep(.n-button) {
|
||||||
|
padding: 20 * 2.5px 16 * 2.5px;
|
||||||
|
border-radius: 4 * 2.5px;
|
||||||
|
}
|
||||||
.search-button {
|
.search-button {
|
||||||
height: 34 * 2.5px;
|
height: 34 * 2.5px;
|
||||||
padding: 7 * 2.5px 12 * 2.5px;
|
padding: 7 * 2.5px 12 * 2.5px;
|
||||||
@ -506,7 +525,6 @@ const handleClickOutside = (event) => {
|
|||||||
font-size: 14 * 2.5px;
|
font-size: 14 * 2.5px;
|
||||||
line-height: 1.375em;
|
line-height: 1.375em;
|
||||||
letter-spacing: 0.48 * 2.5px;
|
letter-spacing: 0.48 * 2.5px;
|
||||||
box-sizing: border-box;
|
|
||||||
&:hover {
|
&:hover {
|
||||||
background: #ff7bac;
|
background: #ff7bac;
|
||||||
color: #fff;
|
color: #fff;
|
||||||
|
@ -1,7 +1,4 @@
|
|||||||
<script setup>
|
<script setup></script>
|
||||||
import { useI18n } from "vue-i18n";
|
|
||||||
const { t } = useI18n();
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<template>
|
<template>
|
||||||
<div class="page-container">
|
<div class="page-container">
|
||||||
@ -15,19 +12,23 @@ const { t } = useI18n();
|
|||||||
<section class="hero-section relative">
|
<section class="hero-section relative">
|
||||||
<div class="hero-content">
|
<div class="hero-content">
|
||||||
<div class="hero-title">
|
<div class="hero-title">
|
||||||
{{ t("product_intro.hero_line1") }}<br />
|
More than just a tool——<br />
|
||||||
{{ t("product_intro.hero_line2") }}<br />
|
Comprehensive growth solutions, <br />
|
||||||
{{ t("product_intro.hero_line3") }}<br />
|
providing a one-stop solution for content creation,<br />
|
||||||
{{ t("product_intro.hero_line4") }}
|
publishing, analysis, and monetization
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="core-value-card">
|
<div class="core-value-card">
|
||||||
<div class="card-content">
|
<div class="card-content">
|
||||||
<div class="card-title">
|
<div class="card-title">Core Value</div>
|
||||||
{{ t("product_intro.core_value_title") }}
|
|
||||||
</div>
|
|
||||||
<div class="card-text">
|
<div class="card-text">
|
||||||
{{ t("product_intro.core_value_text") }}
|
The FIEE-SAAS platform is a one-stop content operation solution
|
||||||
|
tailored for creators in the digital era. The platform utilizes
|
||||||
|
intelligent distribution technology, A1 empowerment tools, and
|
||||||
|
full-chain services,Assist you in efficiently reaching audiences on
|
||||||
|
global mainstream platforms such as TikTok, YouTube, and Instagram,
|
||||||
|
creating a KOL brand effect, unlocking content value, and achieving
|
||||||
|
sustainable growth.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -41,52 +42,59 @@ const { t } = useI18n();
|
|||||||
<section class="features-section">
|
<section class="features-section">
|
||||||
<div class="section-header">
|
<div class="section-header">
|
||||||
<div class="decorator-bar"></div>
|
<div class="decorator-bar"></div>
|
||||||
<div class="section-title">{{ t("product_intro.features_title") }}</div>
|
<div class="section-title">Product Features</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="features-list">
|
<div class="features-list">
|
||||||
<div class="feature-item">
|
<div class="feature-item">
|
||||||
<div class="feature-title">
|
<div class="feature-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.feature_sync") }}
|
One-click Synchronous Publishing
|
||||||
</div>
|
</div>
|
||||||
<div class="feature-description">
|
<div class="feature-description">
|
||||||
{{ t("product_intro.feature_sync_desc") }}
|
Synchronize graphic and video content to TikTok, YouTube, and
|
||||||
|
Instagram platforms at once, saving time on repetitive operations.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="feature-item">
|
<div class="feature-item">
|
||||||
<div class="feature-title">
|
<div class="feature-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.feature_schedule") }}
|
Intelligent Scheduled Publishing
|
||||||
</div>
|
</div>
|
||||||
<div class="feature-description">
|
<div class="feature-description">
|
||||||
{{ t("product_intro.feature_schedule_desc") }}
|
Plan the content release time in advance, support batch scheduling,
|
||||||
|
and accurately grasp the optimal release time of each platform.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="feature-item">
|
<div class="feature-item">
|
||||||
<div class="feature-title">
|
<div class="feature-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.feature_accounts") }}
|
Unified Management of Multiple Accounts
|
||||||
</div>
|
</div>
|
||||||
<div class="feature-description">
|
<div class="feature-description">
|
||||||
{{ t("product_intro.feature_accounts_desc") }}
|
Easily manage multiple accounts on one platform without the need for
|
||||||
|
repeated login and switching, improving team collaboration
|
||||||
|
efficiency.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="feature-item">
|
<div class="feature-item">
|
||||||
<div class="feature-title">
|
<div class="feature-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.feature_library") }}
|
Cloud Content Library
|
||||||
</div>
|
</div>
|
||||||
<div class="feature-description">
|
<div class="feature-description">
|
||||||
{{ t("product_intro.feature_library_desc") }}
|
Safely store and manage all creative materials, access and use them
|
||||||
|
anytime, anywhere, and support quick retrieval and reuse.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="feature-item">
|
<div class="feature-item">
|
||||||
<div class="feature-title">
|
<div class="feature-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.feature_tracking") }}
|
Basic Data Tracking
|
||||||
</div>
|
</div>
|
||||||
<div class="feature-description">
|
<div class="feature-description">
|
||||||
{{ t("product_intro.feature_tracking_desc") }}
|
Visually view the content performance of various platforms,
|
||||||
|
understand core data indicators, and provide a basis for optimizing
|
||||||
|
strategies.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -95,9 +103,7 @@ const { t } = useI18n();
|
|||||||
<section class="solutions-section">
|
<section class="solutions-section">
|
||||||
<div class="section-header">
|
<div class="section-header">
|
||||||
<div class="decorator-bar"></div>
|
<div class="decorator-bar"></div>
|
||||||
<div class="section-title">
|
<div class="section-title">Value Added Solutions</div>
|
||||||
{{ t("product_intro.solutions_title") }}
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
<div class="solutions-content">
|
<div class="solutions-content">
|
||||||
<div class="solutions-list">
|
<div class="solutions-list">
|
||||||
@ -109,10 +115,12 @@ const { t } = useI18n();
|
|||||||
/>
|
/>
|
||||||
<div class="solution-title">
|
<div class="solution-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.sol_kol") }}
|
KOL Brand Promotion Services
|
||||||
</div>
|
</div>
|
||||||
<div class="solution-description">
|
<div class="solution-description">
|
||||||
{{ t("product_intro.sol_kol_desc") }}
|
Efficiently connect high-quality business cooperation
|
||||||
|
opportunities and complete the entire process management from
|
||||||
|
order acceptance to publication within the platform.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="solution-item">
|
<div class="solution-item">
|
||||||
@ -123,10 +131,12 @@ const { t } = useI18n();
|
|||||||
/>
|
/>
|
||||||
<div class="solution-title">
|
<div class="solution-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.sol_content") }}
|
Professional Content Creation Support
|
||||||
</div>
|
</div>
|
||||||
<div class="solution-description">
|
<div class="solution-description">
|
||||||
{{ t("product_intro.sol_content_desc") }}
|
Connect professional shooting and post production teams for you,
|
||||||
|
create high-quality "art+story" content, and strengthen IP
|
||||||
|
influence.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="solution-item">
|
<div class="solution-item">
|
||||||
@ -137,10 +147,12 @@ const { t } = useI18n();
|
|||||||
/>
|
/>
|
||||||
<div class="solution-title">
|
<div class="solution-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.sol_ops") }}
|
Account Operation and Hosting Services
|
||||||
</div>
|
</div>
|
||||||
<div class="solution-description">
|
<div class="solution-description">
|
||||||
{{ t("product_intro.sol_ops_desc") }}
|
From 0 to 1 account positioning, follower growth strategy to
|
||||||
|
monetization cycle, operation experts provide full cycle running
|
||||||
|
and hosting services.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -158,9 +170,7 @@ const { t } = useI18n();
|
|||||||
<div class="advantages-content">
|
<div class="advantages-content">
|
||||||
<div class="advantages-header">
|
<div class="advantages-header">
|
||||||
<div class="decorator-bar"></div>
|
<div class="decorator-bar"></div>
|
||||||
<div class="section-title text-white">
|
<div class="section-title text-white">Our Advantages</div>
|
||||||
{{ t("product_intro.advantages_title") }}
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div style="width: 50%">
|
<div style="width: 50%">
|
||||||
@ -168,47 +178,51 @@ const { t } = useI18n();
|
|||||||
<div class="advantage-item">
|
<div class="advantage-item">
|
||||||
<div class="advantage-title">
|
<div class="advantage-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.adv_time") }}
|
Time Saving
|
||||||
</div>
|
</div>
|
||||||
<div class="advantage-description">
|
<div class="advantage-description">
|
||||||
{{ t("product_intro.adv_time_desc") }}
|
Multi platform publishing efficiency improvement, allowing you
|
||||||
|
to focus on content creation.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="advantage-item">
|
<div class="advantage-item">
|
||||||
<div class="advantage-title">
|
<div class="advantage-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.adv_safe") }}
|
Safe and Reliable
|
||||||
</div>
|
</div>
|
||||||
<div class="advantage-description">
|
<div class="advantage-description">
|
||||||
{{ t("product_intro.adv_safe_desc") }}
|
Enterprise level data encryption and permission control ensure
|
||||||
|
account and content security.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="advantage-item">
|
<div class="advantage-item">
|
||||||
<div class="advantage-title">
|
<div class="advantage-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.adv_consistent") }}
|
Maintain Consistency
|
||||||
</div>
|
</div>
|
||||||
<div class="advantage-description">
|
<div class="advantage-description">
|
||||||
{{ t("product_intro.adv_consistent_desc") }}
|
Ensure that brand information is presented uniformly on all
|
||||||
|
platforms.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="advantage-item">
|
<div class="advantage-item">
|
||||||
<div class="advantage-title">
|
<div class="advantage-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.adv_data") }}
|
Data Driven
|
||||||
</div>
|
</div>
|
||||||
<div class="advantage-description">
|
<div class="advantage-description">
|
||||||
{{ t("product_intro.adv_data_desc") }}
|
Optimizing Content Strategies Based on Actual Performance.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="advantage-item">
|
<div class="advantage-item">
|
||||||
<div class="advantage-title">
|
<div class="advantage-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.adv_easy") }}
|
Easy to Use
|
||||||
</div>
|
</div>
|
||||||
<div class="advantage-description">
|
<div class="advantage-description">
|
||||||
{{ t("product_intro.adv_easy_desc") }}
|
Intuitive interface design, no need for professional technical
|
||||||
|
background.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -237,8 +251,8 @@ const { t } = useI18n();
|
|||||||
/>
|
/>
|
||||||
</svg>
|
</svg>
|
||||||
<div class="cta-title">
|
<div class="cta-title">
|
||||||
{{ t("product_intro.cta_title_line1") }}<br />
|
Get customized <br />
|
||||||
{{ t("product_intro.cta_title_line2") }}
|
solutions for free
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="cta-qr-code">
|
<div class="cta-qr-code">
|
||||||
|
@ -1,7 +1,4 @@
|
|||||||
<script setup>
|
<script setup></script>
|
||||||
import { useI18n } from "vue-i18n";
|
|
||||||
const { t } = useI18n();
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<template>
|
<template>
|
||||||
<div class="page-container">
|
<div class="page-container">
|
||||||
@ -15,19 +12,23 @@ const { t } = useI18n();
|
|||||||
<section class="hero-section relative">
|
<section class="hero-section relative">
|
||||||
<div class="hero-content">
|
<div class="hero-content">
|
||||||
<div class="hero-title">
|
<div class="hero-title">
|
||||||
{{ t("product_intro.hero_line1") }}<br />
|
More than just a tool——<br />
|
||||||
{{ t("product_intro.hero_line2") }}<br />
|
Comprehensive growth solutions, <br />
|
||||||
{{ t("product_intro.hero_line3") }}<br />
|
providing a one-stop solution for content creation,<br />
|
||||||
{{ t("product_intro.hero_line4") }}
|
publishing, analysis, and monetization
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="core-value-card">
|
<div class="core-value-card">
|
||||||
<div class="card-content">
|
<div class="card-content">
|
||||||
<div class="card-title">
|
<div class="card-title">Core Value</div>
|
||||||
{{ t("product_intro.core_value_title") }}
|
|
||||||
</div>
|
|
||||||
<div class="card-text">
|
<div class="card-text">
|
||||||
{{ t("product_intro.core_value_text") }}
|
The FIEE-SAAS platform is a one-stop content operation solution
|
||||||
|
tailored for creators in the digital era. The platform utilizes
|
||||||
|
intelligent distribution technology, A1 empowerment tools, and
|
||||||
|
full-chain services,Assist you in efficiently reaching audiences on
|
||||||
|
global mainstream platforms such as TikTok, YouTube, and Instagram,
|
||||||
|
creating a KOL brand effect, unlocking content value, and achieving
|
||||||
|
sustainable growth.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -41,52 +42,59 @@ const { t } = useI18n();
|
|||||||
<section class="features-section">
|
<section class="features-section">
|
||||||
<div class="section-header">
|
<div class="section-header">
|
||||||
<div class="decorator-bar"></div>
|
<div class="decorator-bar"></div>
|
||||||
<div class="section-title">{{ t("product_intro.features_title") }}</div>
|
<div class="section-title">Product Features</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="features-list">
|
<div class="features-list">
|
||||||
<div class="feature-item">
|
<div class="feature-item">
|
||||||
<div class="feature-title">
|
<div class="feature-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.feature_sync") }}
|
One-click Synchronous Publishing
|
||||||
</div>
|
</div>
|
||||||
<div class="feature-description">
|
<div class="feature-description">
|
||||||
{{ t("product_intro.feature_sync_desc") }}
|
Synchronize graphic and video content to TikTok, YouTube, and
|
||||||
|
Instagram platforms at once, saving time on repetitive operations.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="feature-item">
|
<div class="feature-item">
|
||||||
<div class="feature-title">
|
<div class="feature-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.feature_schedule") }}
|
Intelligent Scheduled Publishing
|
||||||
</div>
|
</div>
|
||||||
<div class="feature-description">
|
<div class="feature-description">
|
||||||
{{ t("product_intro.feature_schedule_desc") }}
|
Plan the content release time in advance, support batch scheduling,
|
||||||
|
and accurately grasp the optimal release time of each platform.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="feature-item">
|
<div class="feature-item">
|
||||||
<div class="feature-title">
|
<div class="feature-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.feature_accounts") }}
|
Unified Management of Multiple Accounts
|
||||||
</div>
|
</div>
|
||||||
<div class="feature-description">
|
<div class="feature-description">
|
||||||
{{ t("product_intro.feature_accounts_desc") }}
|
Easily manage multiple accounts on one platform without the need for
|
||||||
|
repeated login and switching, improving team collaboration
|
||||||
|
efficiency.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="feature-item">
|
<div class="feature-item">
|
||||||
<div class="feature-title">
|
<div class="feature-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.feature_library") }}
|
Cloud Content Library
|
||||||
</div>
|
</div>
|
||||||
<div class="feature-description">
|
<div class="feature-description">
|
||||||
{{ t("product_intro.feature_library_desc") }}
|
Safely store and manage all creative materials, access and use them
|
||||||
|
anytime, anywhere, and support quick retrieval and reuse.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="feature-item">
|
<div class="feature-item">
|
||||||
<div class="feature-title">
|
<div class="feature-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.feature_tracking") }}
|
Basic Data Tracking
|
||||||
</div>
|
</div>
|
||||||
<div class="feature-description">
|
<div class="feature-description">
|
||||||
{{ t("product_intro.feature_tracking_desc") }}
|
Visually view the content performance of various platforms,
|
||||||
|
understand core data indicators, and provide a basis for optimizing
|
||||||
|
strategies.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -95,9 +103,7 @@ const { t } = useI18n();
|
|||||||
<section class="solutions-section">
|
<section class="solutions-section">
|
||||||
<div class="section-header">
|
<div class="section-header">
|
||||||
<div class="decorator-bar"></div>
|
<div class="decorator-bar"></div>
|
||||||
<div class="section-title">
|
<div class="section-title">Value Added Solutions</div>
|
||||||
{{ t("product_intro.solutions_title") }}
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
<div class="solutions-content">
|
<div class="solutions-content">
|
||||||
<div class="solutions-list">
|
<div class="solutions-list">
|
||||||
@ -109,10 +115,12 @@ const { t } = useI18n();
|
|||||||
/>
|
/>
|
||||||
<div class="solution-title">
|
<div class="solution-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.sol_kol") }}
|
KOL Brand Promotion Services
|
||||||
</div>
|
</div>
|
||||||
<div class="solution-description">
|
<div class="solution-description">
|
||||||
{{ t("product_intro.sol_kol_desc") }}
|
Efficiently connect high-quality business cooperation
|
||||||
|
opportunities and complete the entire process management from
|
||||||
|
order acceptance to publication within the platform.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="solution-item">
|
<div class="solution-item">
|
||||||
@ -123,10 +131,12 @@ const { t } = useI18n();
|
|||||||
/>
|
/>
|
||||||
<div class="solution-title">
|
<div class="solution-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.sol_content") }}
|
Professional Content Creation Support
|
||||||
</div>
|
</div>
|
||||||
<div class="solution-description">
|
<div class="solution-description">
|
||||||
{{ t("product_intro.sol_content_desc") }}
|
Connect professional shooting and post production teams for you,
|
||||||
|
create high-quality "art+story" content, and strengthen IP
|
||||||
|
influence.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="solution-item">
|
<div class="solution-item">
|
||||||
@ -137,10 +147,12 @@ const { t } = useI18n();
|
|||||||
/>
|
/>
|
||||||
<div class="solution-title">
|
<div class="solution-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.sol_ops") }}
|
Account Operation and Hosting Services
|
||||||
</div>
|
</div>
|
||||||
<div class="solution-description">
|
<div class="solution-description">
|
||||||
{{ t("product_intro.sol_ops_desc") }}
|
From 0 to 1 account positioning, follower growth strategy to
|
||||||
|
monetization cycle, operation experts provide full cycle running
|
||||||
|
and hosting services.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -158,54 +170,56 @@ const { t } = useI18n();
|
|||||||
<div class="advantages-content">
|
<div class="advantages-content">
|
||||||
<div class="advantages-header">
|
<div class="advantages-header">
|
||||||
<div class="decorator-bar"></div>
|
<div class="decorator-bar"></div>
|
||||||
<div class="section-title text-white">
|
<div class="section-title text-white">Our Advantages</div>
|
||||||
{{ t("product_intro.advantages_title") }}
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
<div class="advantages-list">
|
<div class="advantages-list">
|
||||||
<div class="advantage-item">
|
<div class="advantage-item">
|
||||||
<div class="advantage-title">
|
<div class="advantage-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.adv_time") }}
|
Time Saving
|
||||||
</div>
|
</div>
|
||||||
<div class="advantage-description">
|
<div class="advantage-description">
|
||||||
{{ t("product_intro.adv_time_desc") }}
|
Multi platform publishing efficiency improvement, allowing you to
|
||||||
|
focus on content creation.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="advantage-item">
|
<div class="advantage-item">
|
||||||
<div class="advantage-title">
|
<div class="advantage-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.adv_safe") }}
|
Safe and Reliable
|
||||||
</div>
|
</div>
|
||||||
<div class="advantage-description">
|
<div class="advantage-description">
|
||||||
{{ t("product_intro.adv_safe_desc") }}
|
Enterprise level data encryption and permission control ensure
|
||||||
|
account and content security.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="advantage-item">
|
<div class="advantage-item">
|
||||||
<div class="advantage-title">
|
<div class="advantage-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.adv_consistent") }}
|
Maintain Consistency
|
||||||
</div>
|
</div>
|
||||||
<div class="advantage-description">
|
<div class="advantage-description">
|
||||||
{{ t("product_intro.adv_consistent_desc") }}
|
Ensure that brand information is presented uniformly on all
|
||||||
|
platforms.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="advantage-item">
|
<div class="advantage-item">
|
||||||
<div class="advantage-title">
|
<div class="advantage-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.adv_data") }}
|
Data Driven
|
||||||
</div>
|
</div>
|
||||||
<div class="advantage-description">
|
<div class="advantage-description">
|
||||||
{{ t("product_intro.adv_data_desc") }}
|
Optimizing Content Strategies Based on Actual Performance.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="advantage-item">
|
<div class="advantage-item">
|
||||||
<div class="advantage-title">
|
<div class="advantage-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.adv_easy") }}
|
Easy to Use
|
||||||
</div>
|
</div>
|
||||||
<div class="advantage-description">
|
<div class="advantage-description">
|
||||||
{{ t("product_intro.adv_easy_desc") }}
|
Intuitive interface design, no need for professional technical
|
||||||
|
background.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -233,8 +247,8 @@ const { t } = useI18n();
|
|||||||
/>
|
/>
|
||||||
</svg>
|
</svg>
|
||||||
<div class="cta-title">
|
<div class="cta-title">
|
||||||
{{ t("product_intro.cta_title_line1") }}<br />
|
Get customized <br />
|
||||||
{{ t("product_intro.cta_title_line2") }}
|
solutions for free
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="cta-qr-code">
|
<div class="cta-qr-code">
|
||||||
|
@ -1,7 +1,4 @@
|
|||||||
<script setup>
|
<script setup></script>
|
||||||
import { useI18n } from "vue-i18n";
|
|
||||||
const { t } = useI18n();
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<template>
|
<template>
|
||||||
<div class="page-container">
|
<div class="page-container">
|
||||||
@ -12,19 +9,23 @@ const { t } = useI18n();
|
|||||||
<section class="hero-section relative">
|
<section class="hero-section relative">
|
||||||
<div class="hero-content">
|
<div class="hero-content">
|
||||||
<div class="hero-title">
|
<div class="hero-title">
|
||||||
{{ t("product_intro.hero_line1") }}<br />
|
More than just a tool——<br />
|
||||||
{{ t("product_intro.hero_line2") }}<br />
|
Comprehensive growth <br />solutions, providing a one- <br />stop
|
||||||
{{ t("product_intro.hero_line3") }}<br />
|
solution for content <br />creation, publishing, analysis,<br />
|
||||||
{{ t("product_intro.hero_line4") }}
|
and monetization
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="core-value-card">
|
<div class="core-value-card">
|
||||||
<div class="card-content">
|
<div class="card-content">
|
||||||
<div class="card-title">
|
<div class="card-title">Core Value</div>
|
||||||
{{ t("product_intro.core_value_title") }}
|
|
||||||
</div>
|
|
||||||
<div class="card-text">
|
<div class="card-text">
|
||||||
{{ t("product_intro.core_value_text") }}
|
The FIEE-SAAS platform is a one-stop content operation solution
|
||||||
|
tailored for creators in the digital era. The platform utilizes
|
||||||
|
intelligent distribution technology, A1 empowerment tools, and
|
||||||
|
full-chain services,Assist you in efficiently reaching audiences on
|
||||||
|
global mainstream platforms such as TikTok, YouTube, and Instagram,
|
||||||
|
creating a KOL brand effect, unlocking content value, and achieving
|
||||||
|
sustainable growth.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -38,52 +39,59 @@ const { t } = useI18n();
|
|||||||
<section class="features-section">
|
<section class="features-section">
|
||||||
<div class="section-header">
|
<div class="section-header">
|
||||||
<div class="decorator-bar"></div>
|
<div class="decorator-bar"></div>
|
||||||
<div class="section-title">{{ t("product_intro.features_title") }}</div>
|
<div class="section-title">Product Features</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="features-list">
|
<div class="features-list">
|
||||||
<div class="feature-item">
|
<div class="feature-item">
|
||||||
<div class="feature-title">
|
<div class="feature-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.feature_sync") }}
|
One-click Synchronous Publishing
|
||||||
</div>
|
</div>
|
||||||
<div class="feature-description">
|
<div class="feature-description">
|
||||||
{{ t("product_intro.feature_sync_desc") }}
|
Synchronize graphic and video content to TikTok, YouTube, and
|
||||||
|
Instagram platforms at once, saving time on repetitive operations.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="feature-item">
|
<div class="feature-item">
|
||||||
<div class="feature-title">
|
<div class="feature-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.feature_schedule") }}
|
Intelligent Scheduled Publishing
|
||||||
</div>
|
</div>
|
||||||
<div class="feature-description">
|
<div class="feature-description">
|
||||||
{{ t("product_intro.feature_schedule_desc") }}
|
Plan the content release time in advance, support batch scheduling,
|
||||||
|
and accurately grasp the optimal release time of each platform.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="feature-item">
|
<div class="feature-item">
|
||||||
<div class="feature-title">
|
<div class="feature-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.feature_accounts") }}
|
Unified Management of Multiple Accounts
|
||||||
</div>
|
</div>
|
||||||
<div class="feature-description">
|
<div class="feature-description">
|
||||||
{{ t("product_intro.feature_accounts_desc") }}
|
Easily manage multiple accounts on one platform without the need for
|
||||||
|
repeated login and switching, improving team collaboration
|
||||||
|
efficiency.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="feature-item">
|
<div class="feature-item">
|
||||||
<div class="feature-title">
|
<div class="feature-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.feature_library") }}
|
Cloud Content Library
|
||||||
</div>
|
</div>
|
||||||
<div class="feature-description">
|
<div class="feature-description">
|
||||||
{{ t("product_intro.feature_library_desc") }}
|
Safely store and manage all creative materials, access and use them
|
||||||
|
anytime, anywhere, and support quick retrieval and reuse.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="feature-item">
|
<div class="feature-item">
|
||||||
<div class="feature-title">
|
<div class="feature-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.feature_tracking") }}
|
Basic Data Tracking
|
||||||
</div>
|
</div>
|
||||||
<div class="feature-description">
|
<div class="feature-description">
|
||||||
{{ t("product_intro.feature_tracking_desc") }}
|
Visually view the content performance of various platforms,
|
||||||
|
understand core data indicators, and provide a basis for optimizing
|
||||||
|
strategies.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -92,9 +100,7 @@ const { t } = useI18n();
|
|||||||
<section class="solutions-section">
|
<section class="solutions-section">
|
||||||
<div class="section-header">
|
<div class="section-header">
|
||||||
<div class="decorator-bar"></div>
|
<div class="decorator-bar"></div>
|
||||||
<div class="section-title">
|
<div class="section-title">Value Added Solutions</div>
|
||||||
{{ t("product_intro.solutions_title") }}
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
<div class="solutions-content">
|
<div class="solutions-content">
|
||||||
<div class="solution-image-container">
|
<div class="solution-image-container">
|
||||||
@ -113,10 +119,12 @@ const { t } = useI18n();
|
|||||||
/>
|
/>
|
||||||
<div class="solution-title">
|
<div class="solution-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.sol_kol") }}
|
KOL Brand Promotion Services
|
||||||
</div>
|
</div>
|
||||||
<div class="solution-description">
|
<div class="solution-description">
|
||||||
{{ t("product_intro.sol_kol_desc") }}
|
Efficiently connect high-quality business cooperation
|
||||||
|
opportunities and complete the entire process management from
|
||||||
|
order acceptance to publication within the platform.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="solution-item">
|
<div class="solution-item">
|
||||||
@ -127,10 +135,12 @@ const { t } = useI18n();
|
|||||||
/>
|
/>
|
||||||
<div class="solution-title">
|
<div class="solution-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.sol_content") }}
|
Professional Content Creation Support
|
||||||
</div>
|
</div>
|
||||||
<div class="solution-description">
|
<div class="solution-description">
|
||||||
{{ t("product_intro.sol_content_desc") }}
|
Connect professional shooting and post production teams for you,
|
||||||
|
create high-quality "art+story" content, and strengthen IP
|
||||||
|
influence.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="solution-item">
|
<div class="solution-item">
|
||||||
@ -141,10 +151,12 @@ const { t } = useI18n();
|
|||||||
/>
|
/>
|
||||||
<div class="solution-title">
|
<div class="solution-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.sol_ops") }}
|
Account Operation and Hosting Services
|
||||||
</div>
|
</div>
|
||||||
<div class="solution-description">
|
<div class="solution-description">
|
||||||
{{ t("product_intro.sol_ops_desc") }}
|
From 0 to 1 account positioning, follower growth strategy to
|
||||||
|
monetization cycle, operation experts provide full cycle running
|
||||||
|
and hosting services.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -155,54 +167,56 @@ const { t } = useI18n();
|
|||||||
<div class="advantages-content">
|
<div class="advantages-content">
|
||||||
<div class="advantages-header">
|
<div class="advantages-header">
|
||||||
<div class="decorator-bar"></div>
|
<div class="decorator-bar"></div>
|
||||||
<div class="section-title text-white">
|
<div class="section-title text-white">Our Advantages</div>
|
||||||
{{ t("product_intro.advantages_title") }}
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
<div class="advantages-list">
|
<div class="advantages-list">
|
||||||
<div class="advantage-item">
|
<div class="advantage-item">
|
||||||
<div class="advantage-title">
|
<div class="advantage-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.adv_time") }}
|
Time Saving
|
||||||
</div>
|
</div>
|
||||||
<div class="advantage-description">
|
<div class="advantage-description">
|
||||||
{{ t("product_intro.adv_time_desc") }}
|
Multi platform publishing efficiency improvement, allowing you to
|
||||||
|
focus on content creation.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="advantage-item">
|
<div class="advantage-item">
|
||||||
<div class="advantage-title">
|
<div class="advantage-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.adv_safe") }}
|
Safe and Reliable
|
||||||
</div>
|
</div>
|
||||||
<div class="advantage-description">
|
<div class="advantage-description">
|
||||||
{{ t("product_intro.adv_safe_desc") }}
|
Enterprise level data encryption and permission control ensure
|
||||||
|
account and content security.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="advantage-item">
|
<div class="advantage-item">
|
||||||
<div class="advantage-title">
|
<div class="advantage-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.adv_consistent") }}
|
Maintain Consistency
|
||||||
</div>
|
</div>
|
||||||
<div class="advantage-description">
|
<div class="advantage-description">
|
||||||
{{ t("product_intro.adv_consistent_desc") }}
|
Ensure that brand information is presented uniformly on all
|
||||||
|
platforms.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="advantage-item">
|
<div class="advantage-item">
|
||||||
<div class="advantage-title">
|
<div class="advantage-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.adv_data") }}
|
Data Driven
|
||||||
</div>
|
</div>
|
||||||
<div class="advantage-description">
|
<div class="advantage-description">
|
||||||
{{ t("product_intro.adv_data_desc") }}
|
Optimizing Content Strategies Based on Actual Performance.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="advantage-item">
|
<div class="advantage-item">
|
||||||
<div class="advantage-title">
|
<div class="advantage-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.adv_easy") }}
|
Easy to Use
|
||||||
</div>
|
</div>
|
||||||
<div class="advantage-description">
|
<div class="advantage-description">
|
||||||
{{ t("product_intro.adv_easy_desc") }}
|
Intuitive interface design, no need for professional technical
|
||||||
|
background.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -211,11 +225,7 @@ const { t } = useI18n();
|
|||||||
|
|
||||||
<section class="cta-section">
|
<section class="cta-section">
|
||||||
<div class="cta-content">
|
<div class="cta-content">
|
||||||
<div class="cta-title">
|
<div class="cta-title">Get customized<br />solutions for free</div>
|
||||||
{{ t("product_intro.cta_title_line1") }}<br />{{
|
|
||||||
t("product_intro.cta_title_line2")
|
|
||||||
}}
|
|
||||||
</div>
|
|
||||||
<svg
|
<svg
|
||||||
xmlns="http://www.w3.org/2000/svg"
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
width="32"
|
width="32"
|
||||||
|
@ -1,7 +1,4 @@
|
|||||||
<script setup>
|
<script setup></script>
|
||||||
import { useI18n } from "vue-i18n";
|
|
||||||
const { t } = useI18n();
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<template>
|
<template>
|
||||||
<div class="page-container">
|
<div class="page-container">
|
||||||
@ -13,19 +10,23 @@ const { t } = useI18n();
|
|||||||
<section class="hero-section relative">
|
<section class="hero-section relative">
|
||||||
<div class="hero-content">
|
<div class="hero-content">
|
||||||
<div class="hero-title">
|
<div class="hero-title">
|
||||||
{{ t("product_intro.hero_line1") }}<br />
|
More than just a tool——<br />
|
||||||
{{ t("product_intro.hero_line2") }}<br />
|
Comprehensive growth solutions, <br />providing a one-stop solution
|
||||||
{{ t("product_intro.hero_line3") }}<br />
|
for <br />content creation, publishing, analysis, <br />and
|
||||||
{{ t("product_intro.hero_line4") }}
|
monetization
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="core-value-card">
|
<div class="core-value-card">
|
||||||
<div class="card-content">
|
<div class="card-content">
|
||||||
<div class="card-title">
|
<div class="card-title">Core Value</div>
|
||||||
{{ t("product_intro.core_value_title") }}
|
|
||||||
</div>
|
|
||||||
<div class="card-text">
|
<div class="card-text">
|
||||||
{{ t("product_intro.core_value_text") }}
|
The FIEE-SAAS platform is a one-stop content operation solution
|
||||||
|
tailored for creators in the digital era. The platform utilizes
|
||||||
|
intelligent distribution technology, A1 empowerment tools, and
|
||||||
|
full-chain services,Assist you in efficiently reaching audiences on
|
||||||
|
global mainstream platforms such as TikTok, YouTube, and Instagram,
|
||||||
|
creating a KOL brand effect, unlocking content value, and achieving
|
||||||
|
sustainable growth.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -39,52 +40,59 @@ const { t } = useI18n();
|
|||||||
<section class="features-section">
|
<section class="features-section">
|
||||||
<div class="section-header">
|
<div class="section-header">
|
||||||
<div class="decorator-bar"></div>
|
<div class="decorator-bar"></div>
|
||||||
<div class="section-title">{{ t("product_intro.features_title") }}</div>
|
<div class="section-title">Product Features</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="features-list">
|
<div class="features-list">
|
||||||
<div class="feature-item">
|
<div class="feature-item">
|
||||||
<div class="feature-title">
|
<div class="feature-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.feature_sync") }}
|
One-click Synchronous Publishing
|
||||||
</div>
|
</div>
|
||||||
<div class="feature-description">
|
<div class="feature-description">
|
||||||
{{ t("product_intro.feature_sync_desc") }}
|
Synchronize graphic and video content to TikTok, YouTube, and
|
||||||
|
Instagram platforms at once, saving time on repetitive operations.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="feature-item">
|
<div class="feature-item">
|
||||||
<div class="feature-title">
|
<div class="feature-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.feature_schedule") }}
|
Intelligent Scheduled Publishing
|
||||||
</div>
|
</div>
|
||||||
<div class="feature-description">
|
<div class="feature-description">
|
||||||
{{ t("product_intro.feature_schedule_desc") }}
|
Plan the content release time in advance, support batch scheduling,
|
||||||
|
and accurately grasp the optimal release time of each platform.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="feature-item">
|
<div class="feature-item">
|
||||||
<div class="feature-title">
|
<div class="feature-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.feature_accounts") }}
|
Unified Management of Multiple Accounts
|
||||||
</div>
|
</div>
|
||||||
<div class="feature-description">
|
<div class="feature-description">
|
||||||
{{ t("product_intro.feature_accounts_desc") }}
|
Easily manage multiple accounts on one platform without the need for
|
||||||
|
repeated login and switching, improving team collaboration
|
||||||
|
efficiency.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="feature-item">
|
<div class="feature-item">
|
||||||
<div class="feature-title">
|
<div class="feature-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.feature_library") }}
|
Cloud Content Library
|
||||||
</div>
|
</div>
|
||||||
<div class="feature-description">
|
<div class="feature-description">
|
||||||
{{ t("product_intro.feature_library_desc") }}
|
Safely store and manage all creative materials, access and use them
|
||||||
|
anytime, anywhere, and support quick retrieval and reuse.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="feature-item">
|
<div class="feature-item">
|
||||||
<div class="feature-title">
|
<div class="feature-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.feature_tracking") }}
|
Basic Data Tracking
|
||||||
</div>
|
</div>
|
||||||
<div class="feature-description">
|
<div class="feature-description">
|
||||||
{{ t("product_intro.feature_tracking_desc") }}
|
Visually view the content performance of various platforms,
|
||||||
|
understand core data indicators, and provide a basis for optimizing
|
||||||
|
strategies.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -93,9 +101,7 @@ const { t } = useI18n();
|
|||||||
<section class="solutions-section">
|
<section class="solutions-section">
|
||||||
<div class="section-header">
|
<div class="section-header">
|
||||||
<div class="decorator-bar"></div>
|
<div class="decorator-bar"></div>
|
||||||
<div class="section-title">
|
<div class="section-title">Value Added Solutions</div>
|
||||||
{{ t("product_intro.solutions_title") }}
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
<div class="solutions-content">
|
<div class="solutions-content">
|
||||||
<div class="solution-image-container">
|
<div class="solution-image-container">
|
||||||
@ -114,10 +120,12 @@ const { t } = useI18n();
|
|||||||
/>
|
/>
|
||||||
<div class="solution-title">
|
<div class="solution-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.sol_kol") }}
|
KOL Brand Promotion Services
|
||||||
</div>
|
</div>
|
||||||
<div class="solution-description">
|
<div class="solution-description">
|
||||||
{{ t("product_intro.sol_kol_desc") }}
|
Efficiently connect high-quality business cooperation
|
||||||
|
opportunities and complete the entire process management from
|
||||||
|
order acceptance to publication within the platform.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="solution-item">
|
<div class="solution-item">
|
||||||
@ -128,10 +136,12 @@ const { t } = useI18n();
|
|||||||
/>
|
/>
|
||||||
<div class="solution-title">
|
<div class="solution-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.sol_content") }}
|
Professional Content Creation Support
|
||||||
</div>
|
</div>
|
||||||
<div class="solution-description">
|
<div class="solution-description">
|
||||||
{{ t("product_intro.sol_content_desc") }}
|
Connect professional shooting and post production teams for you,
|
||||||
|
create high-quality "art+story" content, and strengthen IP
|
||||||
|
influence.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="solution-item">
|
<div class="solution-item">
|
||||||
@ -142,10 +152,12 @@ const { t } = useI18n();
|
|||||||
/>
|
/>
|
||||||
<div class="solution-title">
|
<div class="solution-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.sol_ops") }}
|
Account Operation and Hosting Services
|
||||||
</div>
|
</div>
|
||||||
<div class="solution-description">
|
<div class="solution-description">
|
||||||
{{ t("product_intro.sol_ops_desc") }}
|
From 0 to 1 account positioning, follower growth strategy to
|
||||||
|
monetization cycle, operation experts provide full cycle running
|
||||||
|
and hosting services.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -156,54 +168,56 @@ const { t } = useI18n();
|
|||||||
<div class="advantages-content">
|
<div class="advantages-content">
|
||||||
<div class="advantages-header">
|
<div class="advantages-header">
|
||||||
<div class="decorator-bar"></div>
|
<div class="decorator-bar"></div>
|
||||||
<div class="section-title text-white">
|
<div class="section-title text-white">Our Advantages</div>
|
||||||
{{ t("product_intro.advantages_title") }}
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
<div class="advantages-list">
|
<div class="advantages-list">
|
||||||
<div class="advantage-item">
|
<div class="advantage-item">
|
||||||
<div class="advantage-title">
|
<div class="advantage-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.adv_time") }}
|
Time Saving
|
||||||
</div>
|
</div>
|
||||||
<div class="advantage-description">
|
<div class="advantage-description">
|
||||||
{{ t("product_intro.adv_time_desc") }}
|
Multi platform publishing efficiency improvement, allowing you to
|
||||||
|
focus on content creation.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="advantage-item">
|
<div class="advantage-item">
|
||||||
<div class="advantage-title">
|
<div class="advantage-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.adv_safe") }}
|
Safe and Reliable
|
||||||
</div>
|
</div>
|
||||||
<div class="advantage-description">
|
<div class="advantage-description">
|
||||||
{{ t("product_intro.adv_safe_desc") }}
|
Enterprise level data encryption and permission control ensure
|
||||||
|
account and content security.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="advantage-item">
|
<div class="advantage-item">
|
||||||
<div class="advantage-title">
|
<div class="advantage-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.adv_consistent") }}
|
Maintain Consistency
|
||||||
</div>
|
</div>
|
||||||
<div class="advantage-description">
|
<div class="advantage-description">
|
||||||
{{ t("product_intro.adv_consistent_desc") }}
|
Ensure that brand information is presented uniformly on all
|
||||||
|
platforms.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="advantage-item">
|
<div class="advantage-item">
|
||||||
<div class="advantage-title">
|
<div class="advantage-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.adv_data") }}
|
Data Driven
|
||||||
</div>
|
</div>
|
||||||
<div class="advantage-description">
|
<div class="advantage-description">
|
||||||
{{ t("product_intro.adv_data_desc") }}
|
Optimizing Content Strategies Based on Actual Performance.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="advantage-item">
|
<div class="advantage-item">
|
||||||
<div class="advantage-title">
|
<div class="advantage-title">
|
||||||
<div class="vertical-line"></div>
|
<div class="vertical-line"></div>
|
||||||
{{ t("product_intro.adv_easy") }}
|
Easy to Use
|
||||||
</div>
|
</div>
|
||||||
<div class="advantage-description">
|
<div class="advantage-description">
|
||||||
{{ t("product_intro.adv_easy_desc") }}
|
Intuitive interface design, no need for professional technical
|
||||||
|
background.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -231,8 +245,8 @@ const { t } = useI18n();
|
|||||||
/>
|
/>
|
||||||
</svg>
|
</svg>
|
||||||
<div class="cta-title">
|
<div class="cta-title">
|
||||||
{{ t("product_intro.cta_title_line1") }}<br />
|
Get customized <br />
|
||||||
{{ t("product_intro.cta_title_line2") }}
|
solutions for free
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="cta-qr-code">
|
<div class="cta-qr-code">
|
||||||
|
Loading…
Reference in New Issue
Block a user