添加掌上工厂应用
This commit is contained in:
@@ -0,0 +1,136 @@
|
||||
<!-- components/collapse-panel.vue -->
|
||||
<template>
|
||||
<view class="collapse-panel">
|
||||
<view
|
||||
class="collapse-header"
|
||||
@click="toggleCollapse"
|
||||
>
|
||||
<view class="title">
|
||||
<uni-icons type="gear-filled" size="18" color="white" />
|
||||
<text>{{ title }}</text>
|
||||
</view>
|
||||
<view
|
||||
class="arrow"
|
||||
:class="{ 'arrow-open': isOpen }"
|
||||
>
|
||||
<uni-icons type="arrowright" size="18" color="white" />
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<view
|
||||
class="collapse-content"
|
||||
:style="contentStyle"
|
||||
>
|
||||
<slot /> <!-- 插槽保留,支持自定义内容 -->
|
||||
</view>
|
||||
</view>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
// Vue 2 无需导入 Vue 核心API(如ref/computed),直接使用选项式API
|
||||
export default {
|
||||
// 1. 定义组件接收的props(替代 Vue3 的 defineProps)
|
||||
props: {
|
||||
title: {
|
||||
type: String,
|
||||
required: true, // 标题为必填项
|
||||
default: "" // 兜底默认值(避免无值时异常)
|
||||
},
|
||||
duration: {
|
||||
type: Number,
|
||||
default: 300 // 动画时长默认300ms
|
||||
},
|
||||
isBorder: {
|
||||
type: Boolean,
|
||||
default: true // 默认显示边框
|
||||
}
|
||||
},
|
||||
// 2. 响应式数据(替代 Vue3 的 ref)
|
||||
data() {
|
||||
return {
|
||||
isOpen: false, // 控制折叠/展开状态
|
||||
contentHeight: 0 // 内容高度(原代码未实际使用,保留以备扩展)
|
||||
};
|
||||
},
|
||||
// 3. 计算属性(替代 Vue3 的 computed 函数)
|
||||
computed: {
|
||||
// 动态计算内容区域样式(控制展开/折叠动画)
|
||||
contentStyle() {
|
||||
return {
|
||||
"max-height": this.isOpen ? "1000px" : "0", // 展开时最大高度1000px(足够容纳多数内容)
|
||||
"transition": `all ${this.duration}ms ease`, // 动画过渡:时长从props获取
|
||||
"opacity": this.isOpen ? 1 : 0 // 展开时不透明,折叠时透明
|
||||
};
|
||||
}
|
||||
},
|
||||
// 4. 方法定义(替代 Vue3 的直接函数定义)
|
||||
methods: {
|
||||
// 切换折叠/展开状态
|
||||
toggleCollapse() {
|
||||
this.isOpen = !this.isOpen;
|
||||
}
|
||||
}
|
||||
};
|
||||
</script>
|
||||
|
||||
<style lang="scss" scoped>
|
||||
.collapse-panel {
|
||||
margin: 16rpx 0;
|
||||
border-radius: 8rpx;
|
||||
overflow: hidden;
|
||||
border: 1rpx solid #eee;
|
||||
|
||||
// 头部样式(点击区域)
|
||||
.collapse-header {
|
||||
display: flex;
|
||||
justify-content: space-between;
|
||||
align-items: center;
|
||||
padding: 24rpx;
|
||||
background-color: #2bf;
|
||||
color: white;
|
||||
transition: background-color 0.2s;
|
||||
|
||||
// 点击反馈(:active状态)
|
||||
&:active {
|
||||
background-color: #f1f3f5;
|
||||
}
|
||||
|
||||
.title {
|
||||
font-size: 32rpx;
|
||||
font-weight: 500;
|
||||
color: white;
|
||||
display: flex;
|
||||
align-items: center;
|
||||
gap: 12rpx; // 图标与文字间距(原代码未显式设置,补充后排版更整齐)
|
||||
}
|
||||
|
||||
// 箭头样式(旋转动画)
|
||||
.arrow {
|
||||
transition: transform 0.3s ease;
|
||||
color: white;
|
||||
|
||||
// 展开时箭头旋转90度
|
||||
&-open {
|
||||
transform: rotate(90deg);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// 内容区域样式
|
||||
.collapse-content {
|
||||
overflow: hidden;
|
||||
padding: 0 24rpx;
|
||||
background-color: #fff;
|
||||
// 原代码中过渡类(.content-enter-active等)未关联<transition>组件,保留以备后续扩展
|
||||
&-enter-active,
|
||||
&-leave-active {
|
||||
transition: all 0.3s ease;
|
||||
}
|
||||
&-enter-from,
|
||||
&-leave-to {
|
||||
opacity: 0;
|
||||
max-height: 0;
|
||||
}
|
||||
}
|
||||
}
|
||||
</style>
|
||||
130
apps/hand-factory/components/klp-header/klp-header.vue
Normal file
130
apps/hand-factory/components/klp-header/klp-header.vue
Normal file
@@ -0,0 +1,130 @@
|
||||
<template>
|
||||
<view class="custom-header">
|
||||
<!-- 中间产线标题(带下拉选择) -->
|
||||
<view class="header-title-container">
|
||||
<picker
|
||||
mode="selector"
|
||||
:range="lineList"
|
||||
range-key="name"
|
||||
v-model="currentLineIndex"
|
||||
@change="handleLineChange"
|
||||
>
|
||||
<view class="header-title">
|
||||
<text class="line-name">{{ currentLine.name }}</text>
|
||||
<uni-icons type="arrowdown" size="20" color="#666" class="arrow-icon" />
|
||||
</view>
|
||||
</picker>
|
||||
<uni-icons type="down"></uni-icons>
|
||||
</view>
|
||||
|
||||
</view>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
|
||||
export default {
|
||||
// 2. 组件接收的属性(可根据需求扩展)
|
||||
props: {
|
||||
// 可选:外部传入默认选中的产线索引(优先级高于内部默认)
|
||||
defaultLineIndex: {
|
||||
type: Number,
|
||||
default: 0
|
||||
}
|
||||
},
|
||||
// 3. 响应式数据
|
||||
data() {
|
||||
return {
|
||||
// 产线列表(原Tab列表改造,可外部传入,此处保留默认值)
|
||||
lineList: [
|
||||
{ name: "酸轧机组", key: "acidity" },
|
||||
{ name: "彩涂机组", key: "paint" },
|
||||
{ name: "镀锌线一组", key: "zinc1" },
|
||||
{ name: "镀锌线二组", key: "zinc2" },
|
||||
{ name: "镀锌线三组", key: "zinc3" },
|
||||
],
|
||||
// 当前选中的产线索引(关联picker)
|
||||
currentLineIndex: 0,
|
||||
// 当前选中的产线对象(方便模板渲染与回调传递)
|
||||
currentLine: {}
|
||||
};
|
||||
},
|
||||
// 4. 生命周期钩子:初始化当前产线
|
||||
mounted() {
|
||||
// 优先使用外部传入的默认索引,否则用内部默认0
|
||||
this.currentLineIndex = this.defaultLineIndex;
|
||||
// 初始化当前产线对象
|
||||
this.currentLine = this.lineList[this.currentLineIndex];
|
||||
},
|
||||
// 5. 方法定义(交互逻辑与回调触发)
|
||||
methods: {
|
||||
// 产线切换逻辑(picker选择后触发)
|
||||
handleLineChange(e) {
|
||||
// 更新当前选中索引
|
||||
this.currentLineIndex = e.detail.value;
|
||||
// 更新当前选中的产线对象
|
||||
this.currentLine = this.lineList[this.currentLineIndex];
|
||||
// 触发外部回调,传递选中的产线信息(供父组件接收)
|
||||
this.$emit("lineChange", {
|
||||
index: this.currentLineIndex,
|
||||
line: this.currentLine // 包含name和key的完整产线对象
|
||||
});
|
||||
}
|
||||
}
|
||||
};
|
||||
</script>
|
||||
|
||||
<style lang="scss" scoped>
|
||||
// 标题栏整体样式(padding:20rpx 符合需求)
|
||||
.custom-header {
|
||||
display: flex;
|
||||
position: sticky;
|
||||
top: 0;
|
||||
z-index: 9999;
|
||||
align-items: center;
|
||||
padding-top: 40px;
|
||||
padding-bottom: 20px;
|
||||
background-color: #fff;
|
||||
border-bottom: 1rpx solid #eee; // 底部边框分隔,优化视觉
|
||||
box-sizing: border-box;
|
||||
width: 100%;
|
||||
}
|
||||
|
||||
// 左侧返回按钮容器
|
||||
.header-left {
|
||||
width: 60rpx;
|
||||
height: 100%;
|
||||
display: flex;
|
||||
align-items: center;
|
||||
justify-content: flex-start;
|
||||
}
|
||||
|
||||
// 中间产线标题容器(占满剩余宽度,居中对齐)
|
||||
.header-title-container {
|
||||
flex: 1;
|
||||
display: flex;
|
||||
justify-content: center;
|
||||
align-items: center;
|
||||
}
|
||||
|
||||
// 产线标题文本与箭头容器
|
||||
.header-title {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
justify-content: center;
|
||||
}
|
||||
|
||||
// 产线名称样式
|
||||
.line-name {
|
||||
font-size: 32rpx;
|
||||
font-weight: 500;
|
||||
color: #333;
|
||||
margin-right: 8rpx; // 与箭头保持间距
|
||||
}
|
||||
|
||||
// 下拉箭头样式
|
||||
.arrow-icon {
|
||||
transition: transform 0.3s ease;
|
||||
// 可选:选中时旋转箭头(如需扩展可加逻辑)
|
||||
// &.active { transform: rotate(180deg); }
|
||||
}
|
||||
</style>
|
||||
232
apps/hand-factory/components/klp-home/klp-home.vue
Normal file
232
apps/hand-factory/components/klp-home/klp-home.vue
Normal file
@@ -0,0 +1,232 @@
|
||||
<template>
|
||||
<view class="production-dashboard">
|
||||
<!-- 可关闭欢迎条幅 -->
|
||||
<u-alert
|
||||
v-if="showWelcome"
|
||||
title="Ⓘ欢迎使用智能生产监控平台"
|
||||
type="warning"
|
||||
:closable="true"
|
||||
@close="showWelcome = false"
|
||||
class="welcome-banner"
|
||||
icon="notification"
|
||||
/>
|
||||
|
||||
<!-- 操作工具栏 -->
|
||||
<view
|
||||
class="toolbar u-flex u-row-between u-p-20 u-m-b-20 bg-white shadow-sm"
|
||||
>
|
||||
<!-- 日期选择器 -->
|
||||
<uni-datetime-picker type="date" :clear-icon="false" v-model="value1" />
|
||||
</view>
|
||||
|
||||
<!-- 数据可视化图表 -->
|
||||
<view class="chart-box u-m-20 u-p-20 bg-white u-radius-8 shadow-sm">
|
||||
<image
|
||||
src="/static/images/banner/banner03.jpg"
|
||||
mode="widthFix"
|
||||
class="chart-image"
|
||||
@error="handleChartError"
|
||||
/>
|
||||
</view>
|
||||
|
||||
<!-- 智能数据表格 -->
|
||||
<view class="data-table u-m-20 bg-white u-radius-8 shadow-sm">
|
||||
<k-table
|
||||
:columns="columns"
|
||||
:data="tableData"
|
||||
height="800rpx"
|
||||
></k-table>
|
||||
</view>
|
||||
</view>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
import klpTable from "../klp-table/klp-table.vue";
|
||||
|
||||
const STATUS_MAP = {
|
||||
运行中: { type: "success", icon: "checkmark-circle" },
|
||||
待机: { type: "warning", icon: "pause-circle" },
|
||||
故障: { type: "error", icon: "close-circle" },
|
||||
};
|
||||
|
||||
export default {
|
||||
components: { klpTable },
|
||||
data() {
|
||||
return {
|
||||
// 欢迎条幅状态
|
||||
showWelcome: true,
|
||||
value1: '',
|
||||
show: false,
|
||||
// 日期相关
|
||||
selectedDate: Date.now(),
|
||||
datePickerVisible: false,
|
||||
|
||||
// 表格配置
|
||||
tableLayout: "horizontal",
|
||||
columns: [
|
||||
{ title: "设备编号", key: "id", width: "200rpx" },
|
||||
{ title: "产量", key: "output", align: "center" },
|
||||
{ title: "合格率", key: "rate", align: "right" },
|
||||
{ title: "状态", key: "status", width: "150rpx" },
|
||||
],
|
||||
tableData: [
|
||||
{ id: "M-001", output: 2580, rate: "98.5%", status: "运行中" },
|
||||
{ id: "M-002", output: 1820, rate: "97.2%", status: "待机" },
|
||||
{ id: "M-003", output: 3050, rate: "99.1%", status: "故障" },
|
||||
],
|
||||
|
||||
// 图表错误状态
|
||||
chartError: false,
|
||||
};
|
||||
},
|
||||
|
||||
computed: {
|
||||
// 格式化日期
|
||||
formattedDate() {
|
||||
return this.selectedDate;
|
||||
},
|
||||
|
||||
// 布局提示文字
|
||||
layoutText() {
|
||||
return this.tableLayout === "horizontal" ? "表格视图" : "列表视图";
|
||||
},
|
||||
|
||||
// 过滤后的数据(示例过滤逻辑)
|
||||
filteredData() {
|
||||
return this.productionData.filter((item) => {
|
||||
return this.selectedDate % 2 === 0 ? item[1] > 2000 : item;
|
||||
});
|
||||
},
|
||||
},
|
||||
|
||||
mounted() {
|
||||
this.loadPreferences();
|
||||
},
|
||||
|
||||
methods: {
|
||||
// 加载用户偏好设置
|
||||
loadPreferences() {
|
||||
const prefs = uni.getStorageSync("dashboardPrefs") || {};
|
||||
this.showWelcome = prefs.showWelcome !== false;
|
||||
this.tableLayout = prefs.tableLayout || "horizontal";
|
||||
},
|
||||
|
||||
// 保存偏好设置
|
||||
savePreferences() {
|
||||
uni.setStorageSync("dashboardPrefs", {
|
||||
showWelcome: this.showWelcome,
|
||||
tableLayout: this.tableLayout,
|
||||
});
|
||||
},
|
||||
|
||||
// 打开日期选择器
|
||||
openDatePicker() {
|
||||
this.datePickerVisible = true;
|
||||
},
|
||||
|
||||
// 日期确认处理
|
||||
handleDateConfirm(e) {
|
||||
this.selectedDate = e.value;
|
||||
this.datePickerVisible = false;
|
||||
this.refreshData();
|
||||
},
|
||||
|
||||
// 切换表格布局
|
||||
toggleTableLayout() {
|
||||
this.tableLayout =
|
||||
this.tableLayout === "horizontal" ? "vertical" : "horizontal";
|
||||
this.savePreferences();
|
||||
},
|
||||
|
||||
// 获取状态样式
|
||||
getStatusStyle(status) {
|
||||
return STATUS_MAP[status]?.type || "info";
|
||||
},
|
||||
|
||||
// 图表加载失败处理
|
||||
handleChartError() {
|
||||
this.chartError = true;
|
||||
this.$u.toast("图表加载失败,请稍后重试");
|
||||
},
|
||||
|
||||
// 模拟数据刷新
|
||||
async refreshData() {
|
||||
try {
|
||||
// 这里可以添加真实的数据请求逻辑
|
||||
const mockData = await this.$u.mock.wait(500, [...this.productionData]);
|
||||
this.productionData = mockData;
|
||||
} catch (error) {
|
||||
this.$u.toast("数据更新失败");
|
||||
}
|
||||
},
|
||||
},
|
||||
};
|
||||
</script>
|
||||
|
||||
<style lang="scss" scoped>
|
||||
.production-dashboard {
|
||||
background: #f8f9fa;
|
||||
min-height: 100vh;
|
||||
}
|
||||
|
||||
.welcome-banner {
|
||||
margin: 20rpx;
|
||||
border-radius: 16rpx;
|
||||
border: 1rpx solid #ffe58f;
|
||||
}
|
||||
|
||||
.toolbar {
|
||||
border-radius: 16rpx;
|
||||
|
||||
.action-btn {
|
||||
padding: 12rpx 24rpx;
|
||||
background: #f8f9fa;
|
||||
border: 1rpx solid #eee;
|
||||
|
||||
&::v-deep .u-button__text {
|
||||
color: #606266;
|
||||
font-size: 28rpx;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
.chart-box {
|
||||
.chart-image {
|
||||
width: 100%;
|
||||
border-radius: 8rpx;
|
||||
}
|
||||
}
|
||||
|
||||
.data-table {
|
||||
.table-header {
|
||||
background: #fafafa;
|
||||
|
||||
.header-cell {
|
||||
color: #303133;
|
||||
font-weight: 500;
|
||||
padding: 24rpx;
|
||||
}
|
||||
}
|
||||
|
||||
.data-row {
|
||||
&:nth-child(even) {
|
||||
background: #fafafa;
|
||||
}
|
||||
|
||||
.body-cell {
|
||||
color: #606266;
|
||||
padding: 24rpx;
|
||||
text-align: center;
|
||||
}
|
||||
}
|
||||
|
||||
// 响应式布局
|
||||
@media (max-width: 480px) {
|
||||
.header-cell,
|
||||
.body-cell {
|
||||
font-size: 24rpx;
|
||||
padding: 16rpx;
|
||||
}
|
||||
}
|
||||
}
|
||||
</style>
|
||||
@@ -0,0 +1,442 @@
|
||||
<template>
|
||||
<view class="container">
|
||||
<!-- 日月年汇总单选 -->
|
||||
<view class="tab-container">
|
||||
<view
|
||||
v-for="item in timeTabs"
|
||||
:key="item.value"
|
||||
class="tab-item"
|
||||
:class="{ active: activeTab === item.value }"
|
||||
@click="handleTabChange(item.value)"
|
||||
>
|
||||
{{ item.label }}
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<!-- 日期选择器 -->
|
||||
<view class="date-picker">
|
||||
<!-- 日模式 -->
|
||||
<view v-if="activeTab === 'day'" class="date-item">
|
||||
<picker
|
||||
mode="date"
|
||||
:value="startDate"
|
||||
@change="handleDateChange"
|
||||
>
|
||||
<view class="picker-text">选择日期:{{ startDate }}</view>
|
||||
</picker>
|
||||
</view>
|
||||
|
||||
<!-- 月模式 -->
|
||||
<view v-else-if="activeTab === 'month'" class="date-range">
|
||||
<view class="date-item">
|
||||
<picker
|
||||
mode="date"
|
||||
fields="month"
|
||||
:value="startDate"
|
||||
@change="handleStartMonthChange"
|
||||
>
|
||||
<view class="picker-text">开始月份:{{ startDate }}</view>
|
||||
</picker>
|
||||
</view>
|
||||
<view class="date-item">
|
||||
<picker
|
||||
mode="date"
|
||||
fields="month"
|
||||
:value="endDate"
|
||||
:start="startDate"
|
||||
:end="maxMonthEnd"
|
||||
@change="handleEndMonthChange"
|
||||
>
|
||||
<view class="picker-text">结束月份:{{ endDate }}</view>
|
||||
</picker>
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<!-- 年模式 -->
|
||||
<view v-else class="date-range">
|
||||
<view class="date-item">
|
||||
<picker
|
||||
mode="date"
|
||||
fields="year"
|
||||
:value="startDate"
|
||||
@change="handleStartYearChange"
|
||||
>
|
||||
<view class="picker-text">开始年份:{{ startDate }}</view>
|
||||
</picker>
|
||||
</view>
|
||||
<view class="date-item">
|
||||
<picker
|
||||
mode="date"
|
||||
fields="year"
|
||||
:value="endDate"
|
||||
@change="handleEndYearChange"
|
||||
>
|
||||
<view class="picker-text">结束年份:{{ endDate }}</view>
|
||||
</picker>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<!-- 统计图轮播(产量相关) -->
|
||||
<view class="chart-container">
|
||||
<swiper
|
||||
class="chart-swiper"
|
||||
:current="currentSwiperIndex"
|
||||
@change="onSwiperChange"
|
||||
:autoplay="false"
|
||||
:circular="false"
|
||||
:indicator-dots="true"
|
||||
indicator-active-color="#2bf"
|
||||
indicator-color="#e5e5e5"
|
||||
>
|
||||
<swiper-item v-for="(item, index) in chanLiangChartConfig" :key="index">
|
||||
<qiun-data-charts :type="item.type" :chartData="item.chartData" :title="item.title"/>
|
||||
</swiper-item>
|
||||
</swiper>
|
||||
</view>
|
||||
|
||||
<!-- 日期范围汇总 -->
|
||||
<klp-collapse-panel :title="'汇总(' + displayDateRange + ')'">
|
||||
<k-metric-card
|
||||
:items="summaryData"
|
||||
:columns="3"
|
||||
/>
|
||||
|
||||
<!-- 汇总饼图轮播 -->
|
||||
<swiper
|
||||
class="chart-swiper"
|
||||
:autoplay="false"
|
||||
:circular="false"
|
||||
:indicator-dots="true"
|
||||
indicator-active-color="#2bf"
|
||||
indicator-color="#e5e5e5"
|
||||
>
|
||||
<swiper-item v-for="(item, index) in summaryChartConfig" :key="index">
|
||||
<qiun-data-charts type="pie" :opts="item.opts" :chartData="item.chartData" :title="item.title"/>
|
||||
</swiper-item>
|
||||
</swiper>
|
||||
</klp-collapse-panel>
|
||||
</view>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
// 2. 独立工具函数(避免Vue2 data初始化时调用this.methods的问题)
|
||||
/**
|
||||
* 获取默认日期(根据视图类型)
|
||||
* @param {string} type - 视图类型:day/month/year
|
||||
* @returns {string} 格式化后的日期
|
||||
*/
|
||||
function getDefaultDate(type = "day") {
|
||||
const date = new Date();
|
||||
return formatDate(date, type);
|
||||
}
|
||||
|
||||
/**
|
||||
* 格式化日期
|
||||
* @param {Date} date - 日期对象
|
||||
* @param {string} type - 视图类型:day/month/year
|
||||
* @returns {string} 格式化后的日期
|
||||
*/
|
||||
function formatDate(date, type) {
|
||||
const year = date.getFullYear();
|
||||
const month = (date.getMonth() + 1).toString().padStart(2, "0");
|
||||
const day = date.getDate().toString().padStart(2, "0");
|
||||
|
||||
switch (type) {
|
||||
case "day": return `${year}-${month}-${day}`;
|
||||
case "month": return `${year}-${month}`;
|
||||
case "year": return `${year}`;
|
||||
default: return `${year}-${month}-${day}`;
|
||||
}
|
||||
}
|
||||
|
||||
export default {
|
||||
// 4. 响应式数据(替代 Vue3 的 ref)
|
||||
data() {
|
||||
return {
|
||||
// 激活的视图类型(日/月/年)
|
||||
activeTab: "day",
|
||||
// 开始/结束日期(月份/年份)
|
||||
startDate: getDefaultDate(),
|
||||
endDate: getDefaultDate(),
|
||||
// 视图切换选项
|
||||
timeTabs: [
|
||||
{ label: "日视图", value: "day" },
|
||||
{ label: "月视图", value: "month" },
|
||||
{ label: "年视图", value: "year" }
|
||||
],
|
||||
// 产量相关图表配置(轮播)
|
||||
chanLiangChartConfig: [
|
||||
{
|
||||
title: "规格曲线",
|
||||
type: "column",
|
||||
chartData: {} // 初始空对象,后续加载数据
|
||||
},
|
||||
{
|
||||
title: "超产-欠产统计",
|
||||
type: "line",
|
||||
chartData: {} // 初始空对象,后续加载数据
|
||||
},
|
||||
{
|
||||
title: "产量-成材率统计",
|
||||
type: "column",
|
||||
chartData: {
|
||||
categories: ["2016", "2017", "2018", "2019", "2020", "2021"],
|
||||
series: [
|
||||
{ name: "目标值", data: [35, 36, 31, 33, 13, 34] },
|
||||
{ name: "完成量", data: [18, 27, 21, 24, 6, 28] }
|
||||
]
|
||||
} // 固定初始数据
|
||||
}
|
||||
],
|
||||
// 汇总饼图配置(轮播)
|
||||
summaryChartConfig: [
|
||||
{
|
||||
title: "成品厚度统计(mm)",
|
||||
opts: {
|
||||
color: ["#1890FF","#91CB74","#FAC858","#EE6666","#73C0DE","#3CA272","#FC8452","#9A60B4","#ea7ccc"],
|
||||
padding: [5,5,5,5],
|
||||
enableScroll: false,
|
||||
position: "left",
|
||||
float: "left",
|
||||
extra: {
|
||||
pie: {
|
||||
activeOpacity: 0.5,
|
||||
activeRadius: 10,
|
||||
offsetAngle: 0,
|
||||
labelWidth: 15,
|
||||
border: false,
|
||||
borderWidth: 3,
|
||||
borderColor: "#FFFFFF"
|
||||
}
|
||||
}
|
||||
},
|
||||
chartData: JSON.parse(JSON.stringify({
|
||||
series: [{ data: [{"name":"一班","value":50},{"name":"二班","value":30},{"name":"三班","value":20},{"name":"四班","value":18},{"name":"五班","value":8}] }]
|
||||
}))
|
||||
},
|
||||
{
|
||||
title: "钢种统计",
|
||||
opts: {
|
||||
color: ["#1890FF","#91CB74","#FAC858","#EE6666","#73C0DE","#3CA272","#FC8452","#9A60B4","#ea7ccc"],
|
||||
padding: [5,5,5,5],
|
||||
enableScroll: false,
|
||||
extra: {
|
||||
pie: {
|
||||
activeOpacity: 0.5,
|
||||
activeRadius: 10,
|
||||
offsetAngle: 0,
|
||||
labelWidth: 15,
|
||||
border: false,
|
||||
borderWidth: 3,
|
||||
borderColor: "#FFFFFF"
|
||||
}
|
||||
}
|
||||
},
|
||||
chartData: JSON.parse(JSON.stringify({
|
||||
series: [{ data: [{"name":"一班","value":50},{"name":"二班","value":30},{"name":"三班","value":20},{"name":"四班","value":18},{"name":"五班","value":8}] }]
|
||||
}))
|
||||
},
|
||||
{
|
||||
title: "班组统计",
|
||||
opts: {
|
||||
color: ["#1890FF","#91CB74","#FAC858","#EE6666","#73C0DE","#3CA272","#FC8452","#9A60B4","#ea7ccc"],
|
||||
padding: [5,5,5,5],
|
||||
enableScroll: false,
|
||||
extra: {
|
||||
pie: {
|
||||
activeOpacity: 0.5,
|
||||
activeRadius: 10,
|
||||
offsetAngle: 0,
|
||||
labelWidth: 15,
|
||||
border: false,
|
||||
borderWidth: 3,
|
||||
borderColor: "#FFFFFF"
|
||||
}
|
||||
}
|
||||
},
|
||||
chartData: JSON.parse(JSON.stringify({
|
||||
series: [{ data: [{"name":"一班","value":50},{"name":"二班","value":30},{"name":"三班","value":20},{"name":"四班","value":18},{"name":"五班","value":8}] }]
|
||||
}))
|
||||
}
|
||||
],
|
||||
// 轮播图当前索引
|
||||
currentSwiperIndex: 0,
|
||||
// 服务器加载的图表基础数据
|
||||
chartData: {},
|
||||
// 汇总指标卡数据
|
||||
summaryData: [
|
||||
{ label: "生产钢卷数", value: 186 },
|
||||
{ label: "平均宽度", value: 1054, unit: "mm" },
|
||||
{ label: "平均厚度", value: 0.93, unit: "mm" },
|
||||
{ label: "原料总量", value: 3396.47, unit: "t" },
|
||||
{ label: "成品总量", value: 4360.18, unit: "t" },
|
||||
{ label: "成材率", value: 95.99, unit: "%" } // 原代码unit写t,推测是笔误,修正为%
|
||||
]
|
||||
};
|
||||
},
|
||||
// 5. 计算属性(替代 Vue3 的 computed 函数)
|
||||
computed: {
|
||||
// 月模式:最大结束月份(开始月份+1年)
|
||||
maxMonthEnd() {
|
||||
if (!this.startDate) return "";
|
||||
const date = new Date(this.startDate);
|
||||
date.setFullYear(date.getFullYear() + 1);
|
||||
return formatDate(date, "month");
|
||||
},
|
||||
// 日期范围展示文本(汇总标题用)
|
||||
displayDateRange() {
|
||||
switch (this.activeTab) {
|
||||
case "day":
|
||||
return this.startDate;
|
||||
case "month":
|
||||
return `${this.startDate} 至 ${this.endDate}`;
|
||||
case "year":
|
||||
return `${this.startDate} 至 ${this.endDate}`;
|
||||
default:
|
||||
return "";
|
||||
}
|
||||
}
|
||||
},
|
||||
// 6. 生命周期钩子(替代 Vue3 的 onMounted)
|
||||
mounted() {
|
||||
this.getServerData(); // 页面挂载后加载图表数据
|
||||
},
|
||||
// 7. 方法定义(所有交互逻辑与数据处理)
|
||||
methods: {
|
||||
// 切换视图(日/月/年)
|
||||
handleTabChange(tab) {
|
||||
this.activeTab = tab;
|
||||
// 重置日期:日视图首尾一致,月/年视图首尾默认当前
|
||||
const defaultDate = getDefaultDate();
|
||||
this.startDate = defaultDate;
|
||||
this.endDate = tab === "day" ? defaultDate : getDefaultDate(tab);
|
||||
},
|
||||
// 日模式:日期选择器变更
|
||||
handleDateChange(e) {
|
||||
this.startDate = e.detail.value;
|
||||
this.endDate = e.detail.value; // 日视图首尾日期同步
|
||||
},
|
||||
// 月模式:开始月份变更
|
||||
handleStartMonthChange(e) {
|
||||
this.startDate = e.detail.value;
|
||||
// 自动调整结束月份:不超过开始月份+1年
|
||||
const maxEndDate = new Date(this.startDate);
|
||||
maxEndDate.setFullYear(maxEndDate.getFullYear() + 1);
|
||||
const maxEndStr = formatDate(maxEndDate, "month");
|
||||
if (new Date(this.endDate) > maxEndDate) {
|
||||
this.endDate = maxEndStr;
|
||||
}
|
||||
},
|
||||
// 月模式:结束月份变更
|
||||
handleEndMonthChange(e) {
|
||||
this.endDate = e.detail.value;
|
||||
},
|
||||
// 年模式:开始年份变更
|
||||
handleStartYearChange(e) {
|
||||
this.startDate = e.detail.value;
|
||||
},
|
||||
// 年模式:结束年份变更
|
||||
handleEndYearChange(e) {
|
||||
this.endDate = e.detail.value;
|
||||
},
|
||||
// 轮播图切换回调(更新当前索引)
|
||||
onSwiperChange(e) {
|
||||
this.currentSwiperIndex = e.detail.current;
|
||||
},
|
||||
// 模拟从服务器加载图表数据
|
||||
getServerData() {
|
||||
setTimeout(() => {
|
||||
// 模拟服务器返回数据
|
||||
const serverRes = {
|
||||
categories: ["2016", "2017", "2018", "2019", "2020", "2021"],
|
||||
series: [
|
||||
{ name: "目标值", data: [35, 36, 31, 33, 13, 34] },
|
||||
{ name: "完成量", data: [18, 27, 21, 24, 6, 28] }
|
||||
]
|
||||
};
|
||||
// 深拷贝避免引用问题,确保Vue2响应式
|
||||
this.chartData = JSON.parse(JSON.stringify(serverRes));
|
||||
|
||||
// 更新产量图表配置的前两个图表数据(第三个固定)
|
||||
this.chanLiangChartConfig.forEach((item, index) => {
|
||||
if (index < 2) { // 仅前两个图表用服务器数据
|
||||
item.chartData = JSON.parse(JSON.stringify(this.chartData));
|
||||
}
|
||||
});
|
||||
}, 500);
|
||||
}
|
||||
}
|
||||
};
|
||||
</script>
|
||||
|
||||
<style scoped>
|
||||
.container {
|
||||
/* padding: 20rpx; */
|
||||
}
|
||||
|
||||
.tab-container {
|
||||
display: flex;
|
||||
box-sizing: border-box;
|
||||
padding: 20rpx 0;
|
||||
justify-content: space-evenly;
|
||||
background-color: #2bf; /* 修正原代码笔误(2bf → #2bf) */
|
||||
margin-bottom: 30rpx;
|
||||
overflow: hidden;
|
||||
}
|
||||
|
||||
.tab-item {
|
||||
text-align: center;
|
||||
padding: 20rpx;
|
||||
color: white;
|
||||
transition: all 0.3s;
|
||||
border: 2rpx solid transparent;
|
||||
}
|
||||
|
||||
.tab-item.active {
|
||||
color: white;
|
||||
border-color: white;
|
||||
border-radius: 20rpx;
|
||||
}
|
||||
|
||||
.date-picker {
|
||||
padding: 15rpx;
|
||||
background-color: #fff;
|
||||
border-radius: 10rpx;
|
||||
}
|
||||
|
||||
.date-range {
|
||||
display: flex;
|
||||
gap: 20rpx;
|
||||
}
|
||||
|
||||
.date-item {
|
||||
flex: 1;
|
||||
}
|
||||
|
||||
.picker-text {
|
||||
padding: 15rpx;
|
||||
background-color: #f8f8f8;
|
||||
border-radius: 8rpx;
|
||||
color: #666;
|
||||
}
|
||||
|
||||
/* 图表轮播容器样式 */
|
||||
.chart-container {
|
||||
margin: 30rpx 0;
|
||||
background: #fff;
|
||||
border-radius: 16rpx;
|
||||
padding: 20rpx;
|
||||
box-shadow: 0 4rpx 12rpx rgba(0,0,0,0.05);
|
||||
}
|
||||
|
||||
.chart-swiper {
|
||||
height: 500rpx;
|
||||
box-sizing: border-box;
|
||||
}
|
||||
|
||||
/* 图表项标题样式(原代码未生效,保留备用) */
|
||||
.chart-item-title {
|
||||
font-weight: 900;
|
||||
}
|
||||
</style>
|
||||
@@ -0,0 +1,435 @@
|
||||
<template>
|
||||
<view>
|
||||
<!-- 日月年汇总单选 -->
|
||||
<view class="tab-container">
|
||||
<view
|
||||
v-for="item in timeTabs"
|
||||
:key="item.value"
|
||||
class="tab-item"
|
||||
:class="{ active: activeTab === item.value }"
|
||||
@click="handleTabChange(item.value)"
|
||||
>
|
||||
{{ item.label }}
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<!-- 日期选择器 -->
|
||||
<view class="date-picker">
|
||||
<!-- 日模式 -->
|
||||
<view v-if="activeTab === 'day'" class="date-item">
|
||||
<picker mode="date" :value="startDate" @change="handleDateChange">
|
||||
<view class="picker-text">选择日期:{{ startDate }}</view>
|
||||
</picker>
|
||||
</view>
|
||||
|
||||
<!-- 月模式 -->
|
||||
<view v-else-if="activeTab === 'month'" class="date-range">
|
||||
<view class="date-item">
|
||||
<picker
|
||||
mode="date"
|
||||
fields="month"
|
||||
:value="startDate"
|
||||
@change="handleStartMonthChange"
|
||||
>
|
||||
<view class="picker-text">开始月份:{{ startDate }}</view>
|
||||
</picker>
|
||||
</view>
|
||||
<view class="date-item">
|
||||
<picker
|
||||
mode="date"
|
||||
fields="month"
|
||||
:value="endDate"
|
||||
:start="startDate"
|
||||
:end="maxMonthEnd"
|
||||
@change="handleEndMonthChange"
|
||||
>
|
||||
<view class="picker-text">结束月份:{{ endDate }}</view>
|
||||
</picker>
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<!-- 年模式 -->
|
||||
<view v-else class="date-range">
|
||||
<view class="date-item">
|
||||
<picker
|
||||
mode="date"
|
||||
fields="year"
|
||||
:value="startDate"
|
||||
@change="handleStartYearChange"
|
||||
>
|
||||
<view class="picker-text">开始年份:{{ startDate }}</view>
|
||||
</picker>
|
||||
</view>
|
||||
<view class="date-item">
|
||||
<picker
|
||||
mode="date"
|
||||
fields="year"
|
||||
:value="endDate"
|
||||
@change="handleEndYearChange"
|
||||
>
|
||||
<view class="picker-text">结束年份:{{ endDate }}</view>
|
||||
</picker>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<!-- 停机时间,作业率统计图表 -->
|
||||
<view v-if="activeTab != 'day'">
|
||||
<qiun-data-charts type="mix" :chartData="chartData" :opts="opts" />
|
||||
</view>
|
||||
|
||||
<view>
|
||||
<klp-collapse-panel :title="'汇总(' + displayDateRange + ')'">
|
||||
<k-metric-card
|
||||
:items="summaryData"
|
||||
></k-metric-card>
|
||||
</klp-collapse-panel>
|
||||
</view>
|
||||
|
||||
<view v-if="activeTab == 'day'">
|
||||
<klp-collapse-panel title="详细信息">
|
||||
<k-table :columns="columns" :data="tableData"></k-table>
|
||||
</klp-collapse-panel>
|
||||
</view>
|
||||
|
||||
<view style="margin-top: 30rpx;">
|
||||
<qiun-data-charts type="pie" :chartData="pieChartData" :opts="pieOpts" />
|
||||
</view>
|
||||
</view>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
// 2. 独立工具函数(避免data初始化时调用this.methods的问题)
|
||||
/**
|
||||
* 获取默认日期(根据视图类型)
|
||||
* @param {string} type - 视图类型:day/month/year
|
||||
* @returns {string} 格式化后的日期
|
||||
*/
|
||||
function getDefaultDate(type = "day") {
|
||||
const date = new Date();
|
||||
const year = date.getFullYear();
|
||||
const month = (date.getMonth() + 1).toString().padStart(2, "0");
|
||||
const day = date.getDate().toString().padStart(2, "0");
|
||||
|
||||
switch (type) {
|
||||
case "day":
|
||||
return `${year}-${month}-${day}`;
|
||||
case "month":
|
||||
return `${year}-${month}`;
|
||||
case "year":
|
||||
return `${year}`;
|
||||
default:
|
||||
return `${year}-${month}-${day}`;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* 格式化日期
|
||||
* @param {Date} date - 日期对象
|
||||
* @param {string} type - 视图类型:day/month/year
|
||||
* @returns {string} 格式化后的日期
|
||||
*/
|
||||
function formatDate(date, type) {
|
||||
const year = date.getFullYear();
|
||||
const month = (date.getMonth() + 1).toString().padStart(2, "0");
|
||||
const day = date.getDate().toString().padStart(2, "0");
|
||||
|
||||
switch (type) {
|
||||
case "day":
|
||||
return `${year}-${month}-${day}`;
|
||||
case "month":
|
||||
return `${year}-${month}`;
|
||||
case "year":
|
||||
return `${year}`;
|
||||
default:
|
||||
return `${year}-${month}-${day}`;
|
||||
}
|
||||
}
|
||||
|
||||
export default {
|
||||
// 4. 响应式数据(替代 Vue3 的 ref)
|
||||
data() {
|
||||
return {
|
||||
// 激活的视图类型(日/月/年)
|
||||
activeTab: "day",
|
||||
// 开始日期/月份/年份
|
||||
startDate: getDefaultDate(),
|
||||
// 结束日期/月份/年份
|
||||
endDate: getDefaultDate(),
|
||||
// 视图切换选项
|
||||
timeTabs: [
|
||||
{ label: "日视图", value: "day" },
|
||||
{ label: "月视图", value: "month" },
|
||||
{ label: "年视图", value: "year" }
|
||||
],
|
||||
// 混合图表数据
|
||||
chartData: {
|
||||
categories: ["2018", "2019", "2020", "2021", "2022", "2023"],
|
||||
series: [
|
||||
{
|
||||
name: "曲面",
|
||||
type: "area",
|
||||
style: "curve",
|
||||
data: [70, 50, 85, 130, 64, 88]
|
||||
},
|
||||
{
|
||||
name: "柱1",
|
||||
index: 1,
|
||||
type: "column",
|
||||
data: [40, { value: 30, color: "#f04864" }, 55, 110, 24, 58]
|
||||
},
|
||||
{
|
||||
name: "柱2",
|
||||
index: 1,
|
||||
type: "column",
|
||||
data: [50, 20, 75, 60, 34, 38]
|
||||
},
|
||||
{
|
||||
name: "曲线",
|
||||
type: "line",
|
||||
style: "curve",
|
||||
color: "#1890ff",
|
||||
disableLegend: true,
|
||||
data: [70, 50, 85, 130, 64, 88]
|
||||
},
|
||||
{
|
||||
name: "折线",
|
||||
type: "line",
|
||||
color: "#2fc25b",
|
||||
data: [120, 140, 105, 170, 95, 160]
|
||||
},
|
||||
{
|
||||
name: "点",
|
||||
index: 2,
|
||||
type: "point",
|
||||
color: "#f04864",
|
||||
data: [100, 80, 125, 150, 112, 132]
|
||||
}
|
||||
]
|
||||
},
|
||||
// 混合图表配置
|
||||
opts: {
|
||||
color: [
|
||||
"#1890FF",
|
||||
"#91CB74",
|
||||
"#FAC858",
|
||||
"#EE6666",
|
||||
"#73C0DE",
|
||||
"#3CA272",
|
||||
"#FC8452",
|
||||
"#9A60B4",
|
||||
"#ea7ccc"
|
||||
],
|
||||
padding: [15, 15, 0, 15],
|
||||
enableScroll: false,
|
||||
legend: {},
|
||||
xAxis: {
|
||||
disableGrid: true,
|
||||
title: "单位:年"
|
||||
},
|
||||
yAxis: {
|
||||
disabled: false,
|
||||
disableGrid: false,
|
||||
splitNumber: 5,
|
||||
gridType: "dash",
|
||||
dashLength: 4,
|
||||
gridColor: "#CCCCCC",
|
||||
padding: 10,
|
||||
showTitle: true,
|
||||
data: [
|
||||
{ position: "left", title: "折线" },
|
||||
{ position: "right", min: 0, max: 200, title: "柱状图", textAlign: "left" },
|
||||
{ position: "right", min: 0, max: 200, title: "点", textAlign: "left" }
|
||||
]
|
||||
},
|
||||
extra: { mix: { column: { width: 20 } } }
|
||||
},
|
||||
// 汇总数据(供 k-metric-card 使用)
|
||||
summaryData: [
|
||||
{ label: "停机时间", value: 730, unit: "min" },
|
||||
{ label: "停机次数", value: 9 },
|
||||
{ label: "作业率", value: 49.31, unit: "%" }
|
||||
],
|
||||
// 表格列配置(日视图详细信息)
|
||||
columns: [
|
||||
{ title: "起止时间", key: "time" },
|
||||
{ title: "持续时间", key: "duration" },
|
||||
{ title: "备注", key: "remark" },
|
||||
{ title: "机组", key: "machine" }
|
||||
],
|
||||
// 表格数据(日视图详细信息)
|
||||
tableData: [
|
||||
{
|
||||
time: "2022-01-01 08:00:00",
|
||||
duration: "30min",
|
||||
remark: "设备维护",
|
||||
machine: "1号机"
|
||||
},
|
||||
{
|
||||
time: "2022-01-01 10:00:00",
|
||||
duration: "20min",
|
||||
remark: "设备故障",
|
||||
machine: "2号机"
|
||||
},
|
||||
{
|
||||
time: "2022-01-01 12:00:00",
|
||||
duration: "40min",
|
||||
remark: "设备维护",
|
||||
machine: "3号机"
|
||||
}
|
||||
],
|
||||
// 饼图数据
|
||||
pieChartData: {
|
||||
series: [
|
||||
{
|
||||
data: [
|
||||
{ name: "一班", value: 50 },
|
||||
{ name: "二班", value: 30 },
|
||||
{ name: "三班", value: 20 },
|
||||
{ name: "四班", value: 18, labelText: "四班:18人" },
|
||||
{ name: "五班", value: 8 }
|
||||
]
|
||||
}
|
||||
]
|
||||
},
|
||||
// 饼图配置
|
||||
pieOpts: {
|
||||
color: [
|
||||
"#1890FF",
|
||||
"#91CB74",
|
||||
"#FAC858",
|
||||
"#EE6666",
|
||||
"#73C0DE",
|
||||
"#3CA272",
|
||||
"#FC8452",
|
||||
"#9A60B4",
|
||||
"#ea7ccc"
|
||||
],
|
||||
padding: [5, 5, 5, 5],
|
||||
enableScroll: false,
|
||||
extra: {
|
||||
pie: {
|
||||
activeOpacity: 0.5,
|
||||
activeRadius: 10,
|
||||
offsetAngle: 0,
|
||||
labelWidth: 15,
|
||||
border: true,
|
||||
borderWidth: 3,
|
||||
borderColor: "#FFFFFF"
|
||||
}
|
||||
}
|
||||
}
|
||||
};
|
||||
},
|
||||
// 5. 计算属性(替代 Vue3 的 computed 函数)
|
||||
computed: {
|
||||
// 月模式:最大结束月份(开始月份+1年)
|
||||
maxMonthEnd() {
|
||||
if (!this.startDate) return "";
|
||||
const date = new Date(this.startDate);
|
||||
date.setFullYear(date.getFullYear() + 1);
|
||||
return formatDate(date, "month");
|
||||
},
|
||||
// 日期范围展示文本(汇总标题用)
|
||||
displayDateRange() {
|
||||
switch (this.activeTab) {
|
||||
case "day":
|
||||
return this.startDate;
|
||||
case "month":
|
||||
return `${this.startDate} 至 ${this.endDate}`;
|
||||
case "year":
|
||||
return `${this.startDate} 至 ${this.endDate}`;
|
||||
default:
|
||||
return "";
|
||||
}
|
||||
}
|
||||
},
|
||||
// 6. 方法定义(所有交互逻辑放这里)
|
||||
methods: {
|
||||
// 切换视图(日/月/年)
|
||||
handleTabChange(tab) {
|
||||
this.activeTab = tab;
|
||||
// 重置日期:日视图首尾日期相同,月/年视图首尾默认当前
|
||||
const defaultDate = getDefaultDate();
|
||||
this.startDate = defaultDate;
|
||||
this.endDate = tab === "day" ? defaultDate : getDefaultDate(tab);
|
||||
},
|
||||
// 日模式:日期选择器变更
|
||||
handleDateChange(e) {
|
||||
this.startDate = e.detail.value;
|
||||
this.endDate = e.detail.value; // 日模式首尾日期一致
|
||||
},
|
||||
// 月模式:开始月份变更
|
||||
handleStartMonthChange(e) {
|
||||
this.startDate = e.detail.value;
|
||||
// 自动调整结束月份:不超过开始月份+1年
|
||||
const maxEndDate = new Date(this.startDate);
|
||||
maxEndDate.setFullYear(maxEndDate.getFullYear() + 1);
|
||||
const maxEndStr = formatDate(maxEndDate, "month");
|
||||
if (new Date(this.endDate) > maxEndDate) {
|
||||
this.endDate = maxEndStr;
|
||||
}
|
||||
},
|
||||
// 月模式:结束月份变更
|
||||
handleEndMonthChange(e) {
|
||||
this.endDate = e.detail.value;
|
||||
},
|
||||
// 年模式:开始年份变更
|
||||
handleStartYearChange(e) {
|
||||
this.startDate = e.detail.value;
|
||||
},
|
||||
// 年模式:结束年份变更
|
||||
handleEndYearChange(e) {
|
||||
this.endDate = e.detail.value;
|
||||
}
|
||||
}
|
||||
};
|
||||
</script>
|
||||
|
||||
<style scoped>
|
||||
.tab-container {
|
||||
display: flex;
|
||||
box-sizing: border-box;
|
||||
padding: 20rpx 0;
|
||||
justify-content: space-evenly;
|
||||
background-color: #2bf; /* 原代码笔误“2bf”,修正为“#2bf” */
|
||||
margin-bottom: 30rpx;
|
||||
overflow: hidden;
|
||||
}
|
||||
|
||||
.tab-item {
|
||||
text-align: center;
|
||||
padding: 20rpx;
|
||||
color: white;
|
||||
transition: all 0.3s;
|
||||
border: 2rpx solid transparent;
|
||||
}
|
||||
|
||||
.tab-item.active {
|
||||
color: white;
|
||||
border-color: white;
|
||||
border-radius: 20rpx;
|
||||
}
|
||||
|
||||
.date-picker {
|
||||
padding: 15rpx;
|
||||
background-color: #fff;
|
||||
border-radius: 10rpx;
|
||||
}
|
||||
|
||||
.date-range {
|
||||
display: flex;
|
||||
gap: 20rpx;
|
||||
}
|
||||
|
||||
.date-item {
|
||||
flex: 1;
|
||||
}
|
||||
|
||||
.picker-text {
|
||||
padding: 15rpx;
|
||||
background-color: #f8f8f8;
|
||||
border-radius: 8rpx;
|
||||
color: #666;
|
||||
}
|
||||
</style>
|
||||
@@ -0,0 +1,198 @@
|
||||
<template>
|
||||
<view>
|
||||
<view class="month-picker">
|
||||
<picker
|
||||
mode="date"
|
||||
fields="month"
|
||||
:value="selectedMonth"
|
||||
:start="startDate"
|
||||
:end="endDate"
|
||||
@change="handleMonthChange"
|
||||
>
|
||||
<view class="picker-content">
|
||||
<!-- 左箭头 -->
|
||||
<view
|
||||
class="arrow"
|
||||
@click.stop="changeMonth(-1)"
|
||||
:class="{ disabled: isMinMonth }"
|
||||
>
|
||||
◀
|
||||
</view>
|
||||
|
||||
<view class="month-display">
|
||||
<text class="label">选择月份:</text>
|
||||
<text class="month-text">{{ formattedMonth }}</text>
|
||||
</view>
|
||||
|
||||
<!-- 右箭头 -->
|
||||
<view
|
||||
class="arrow"
|
||||
@click.stop="changeMonth(1)"
|
||||
:class="{ disabled: isMaxMonth }"
|
||||
>
|
||||
▶
|
||||
</view>
|
||||
|
||||
<text class="icon">▼</text>
|
||||
</view>
|
||||
</picker>
|
||||
</view>
|
||||
|
||||
<view>
|
||||
<k-table :columns="columns" :data="tableData"></k-table>
|
||||
</view>
|
||||
</view>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
// 1. 导入组件(路径需根据实际项目结构调整)
|
||||
import klpTable from "../klp-ui/k-table/k-table.vue";
|
||||
|
||||
// 2. 独立工具函数(避免data初始化时调用this.methods的问题)
|
||||
function getCurrentMonth() {
|
||||
const date = new Date();
|
||||
const year = date.getFullYear();
|
||||
const month = (date.getMonth() + 1).toString().padStart(2, "0");
|
||||
return `${year}-${month}`;
|
||||
}
|
||||
|
||||
function getDefaultMonth() {
|
||||
return getCurrentMonth();
|
||||
}
|
||||
|
||||
export default {
|
||||
// 3. 显式注册局部组件(Vue 2 必需)
|
||||
components: {
|
||||
klpTable
|
||||
},
|
||||
// 4. 响应式数据(替代 Vue 3 的 ref)
|
||||
data() {
|
||||
return {
|
||||
// 默认选中当前月份
|
||||
selectedMonth: getDefaultMonth(),
|
||||
// 可选月份范围:2020年1月 - 当前月
|
||||
startDate: "2020-01",
|
||||
endDate: getCurrentMonth(),
|
||||
// 表格列配置
|
||||
columns: [
|
||||
{ title: '班组', key: 'team' },
|
||||
{ title: '作业次数', key: 'workCount' },
|
||||
{ title: '原始产量', key: 'originalOutput' },
|
||||
{ title: '成材率', key: 'yieldRate' },
|
||||
{ title: '厚度合格率', key: 'thicknessPassRate' }
|
||||
],
|
||||
// 表格数据
|
||||
tableData: [
|
||||
{ team: '班组1', workCount: 100, originalOutput: 1000, yieldRate: '95%', thicknessPassRate: '90%' },
|
||||
{ team: '班组2', workCount: 120, originalOutput: 1200, yieldRate: '92%', thicknessPassRate: '88%' },
|
||||
{ team: '班组3', workCount: 90, originalOutput: 900, yieldRate: '93%', thicknessPassRate: '91%' },
|
||||
{ team: '班组4', workCount: 110, originalOutput: 1100, yieldRate: '94%', thicknessPassRate: '89%' }
|
||||
]
|
||||
};
|
||||
},
|
||||
// 5. 计算属性(替代 Vue 3 的 computed 函数)
|
||||
computed: {
|
||||
// 是否为最小可选月份(2020-01)
|
||||
isMinMonth() {
|
||||
return this.selectedMonth === this.startDate;
|
||||
},
|
||||
// 是否为最大可选月份(当前月)
|
||||
isMaxMonth() {
|
||||
return this.selectedMonth === this.endDate;
|
||||
},
|
||||
// 格式化月份显示(如:2024年05月)
|
||||
formattedMonth() {
|
||||
const [year, month] = this.selectedMonth.split("-");
|
||||
return `${year}年${month}月`;
|
||||
}
|
||||
},
|
||||
// 6. 方法定义(所有函数需放在 methods 中)
|
||||
methods: {
|
||||
// 选择器切换月份(picker组件自带事件)
|
||||
handleMonthChange(e) {
|
||||
this.selectedMonth = e.detail.value;
|
||||
},
|
||||
// 箭头切换月份(左减1,右加1)
|
||||
changeMonth(step) {
|
||||
// 解析当前选中的年月
|
||||
const [year, month] = this.selectedMonth.split("-").map(Number);
|
||||
// 计算目标月份(month从0开始,需-1后+step)
|
||||
const targetDate = new Date(year, month - 1 + step);
|
||||
// 格式化目标月份为 YYYY-MM
|
||||
const targetMonth = `${targetDate.getFullYear()}-${(targetDate.getMonth() + 1).toString().padStart(2, "0")}`;
|
||||
|
||||
// 边界校验:不能小于最小月,不能大于最大月
|
||||
if (this.compareMonths(targetMonth, this.startDate) < 0) return;
|
||||
if (this.compareMonths(targetMonth, this.endDate) > 0) return;
|
||||
|
||||
// 更新选中月份
|
||||
this.selectedMonth = targetMonth;
|
||||
},
|
||||
// 比较两个月份(a > b 返回1,a = b 返回0,a < b 返回-1)
|
||||
compareMonths(a, b) {
|
||||
const [aYear, aMonth] = a.split("-").map(Number);
|
||||
const [bYear, bMonth] = b.split("-").map(Number);
|
||||
|
||||
if (aYear !== bYear) return aYear - bYear;
|
||||
return aMonth - bMonth;
|
||||
}
|
||||
}
|
||||
};
|
||||
</script>
|
||||
|
||||
<style scoped>
|
||||
.month-picker {
|
||||
padding: 20rpx;
|
||||
}
|
||||
|
||||
.picker-content {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
padding: 20rpx;
|
||||
background-color: #f8f8f8;
|
||||
border-radius: 8rpx;
|
||||
border: 1rpx solid #eee;
|
||||
}
|
||||
|
||||
.month-display {
|
||||
flex: 1;
|
||||
display: flex;
|
||||
align-items: center;
|
||||
justify-content: center;
|
||||
}
|
||||
|
||||
.arrow {
|
||||
padding: 0 20rpx;
|
||||
font-size: 28rpx;
|
||||
color: #2bf;
|
||||
cursor: pointer;
|
||||
transition: opacity 0.3s;
|
||||
}
|
||||
|
||||
.arrow:active {
|
||||
opacity: 0.7;
|
||||
}
|
||||
|
||||
.arrow.disabled {
|
||||
color: #ccc;
|
||||
pointer-events: none;
|
||||
}
|
||||
|
||||
.label {
|
||||
color: #666;
|
||||
font-size: 28rpx;
|
||||
}
|
||||
|
||||
.month-text {
|
||||
color: #333;
|
||||
font-weight: bold;
|
||||
margin: 0 15rpx;
|
||||
}
|
||||
|
||||
.icon {
|
||||
color: #999;
|
||||
font-size: 24rpx;
|
||||
transform: scale(0.8);
|
||||
margin-left: 20rpx;
|
||||
}
|
||||
</style>
|
||||
26
apps/hand-factory/components/klp-ui/k-chart/k-chart.vue
Normal file
26
apps/hand-factory/components/klp-ui/k-chart/k-chart.vue
Normal file
@@ -0,0 +1,26 @@
|
||||
<template>
|
||||
<qiun-data-charts :type="type" :chartData="chartData" :opts="opts"/>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
export default {
|
||||
// 定义接收的属性(替代 Vue3 的 defineProps)
|
||||
props: {
|
||||
// 图表类型(如line、column、pie等)
|
||||
type: {
|
||||
type: String,
|
||||
required: true // 图表类型为必填项
|
||||
},
|
||||
// 图表数据(包含categories和series等)
|
||||
chartData: {
|
||||
type: Object,
|
||||
required: true // 图表数据为必填项
|
||||
},
|
||||
// 图表配置项(如样式、坐标轴设置等)
|
||||
opts: {
|
||||
type: Object,
|
||||
default: () => ({}) // 配置项默认为空对象
|
||||
}
|
||||
}
|
||||
}
|
||||
</script>
|
||||
@@ -0,0 +1,145 @@
|
||||
<template>
|
||||
<view class="collapse-panel">
|
||||
<view
|
||||
class="collapse-header"
|
||||
@click="toggleCollapse"
|
||||
>
|
||||
<view class="title">
|
||||
<uni-icons type="gear-filled" size="18" color="white" />
|
||||
<text>{{ title }}</text>
|
||||
</view>
|
||||
<view class="header-right">
|
||||
<view class="extra" @click.stop>
|
||||
<slot name="extra"></slot>
|
||||
</view>
|
||||
<view
|
||||
class="arrow"
|
||||
:class="{ 'arrow-open': isOpen }"
|
||||
>
|
||||
<uni-icons type="arrowright" size="18" color="white" />
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<view
|
||||
class="collapse-content"
|
||||
:style="contentStyle"
|
||||
>
|
||||
<slot />
|
||||
</view>
|
||||
</view>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
export default {
|
||||
// 定义组件接收的属性
|
||||
props: {
|
||||
title: {
|
||||
type: String,
|
||||
required: true
|
||||
},
|
||||
duration: {
|
||||
type: Number,
|
||||
default: 300
|
||||
},
|
||||
isBorder: {
|
||||
type: Boolean,
|
||||
default: true
|
||||
}
|
||||
},
|
||||
// 响应式数据
|
||||
data() {
|
||||
return {
|
||||
isOpen: false,
|
||||
contentHeight: 0
|
||||
};
|
||||
},
|
||||
// 计算属性
|
||||
computed: {
|
||||
contentStyle() {
|
||||
return {
|
||||
'max-height': this.isOpen ? '1000px' : '0',
|
||||
'transition': `all ${this.duration}ms ease`,
|
||||
'opacity': this.isOpen ? 1 : 0
|
||||
};
|
||||
}
|
||||
},
|
||||
// 方法定义
|
||||
methods: {
|
||||
toggleCollapse() {
|
||||
this.isOpen = !this.isOpen;
|
||||
}
|
||||
}
|
||||
};
|
||||
</script>
|
||||
|
||||
<style lang="scss" scoped>
|
||||
.collapse-panel {
|
||||
margin: 16rpx 0;
|
||||
border-radius: 8rpx;
|
||||
overflow: hidden;
|
||||
border: 1rpx solid #eee;
|
||||
|
||||
.collapse-header {
|
||||
display: flex;
|
||||
justify-content: space-between;
|
||||
align-items: center;
|
||||
padding: 24rpx;
|
||||
background-color: #2bf;
|
||||
color: white;
|
||||
transition: background-color 0.2s;
|
||||
|
||||
&:active {
|
||||
background-color: #f1f3f5;
|
||||
}
|
||||
|
||||
.title {
|
||||
font-size: 32rpx;
|
||||
font-weight: 500;
|
||||
color: white;
|
||||
display: flex;
|
||||
align-items: center;
|
||||
gap: 12rpx;
|
||||
}
|
||||
|
||||
.header-right {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
gap: 16rpx;
|
||||
}
|
||||
|
||||
.extra {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
}
|
||||
|
||||
.arrow {
|
||||
transition: transform 0.3s ease;
|
||||
color: white;
|
||||
|
||||
&-open {
|
||||
transform: rotate(90deg);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
.collapse-content {
|
||||
overflow: hidden;
|
||||
padding: 0 24rpx;
|
||||
background-color: #fff;
|
||||
|
||||
// 展开动画
|
||||
&-enter-active,
|
||||
&-leave-active {
|
||||
transition: all 0.3s ease;
|
||||
}
|
||||
|
||||
&-enter-from,
|
||||
&-leave-to {
|
||||
opacity: 0;
|
||||
max-height: 0;
|
||||
}
|
||||
}
|
||||
}
|
||||
</style>
|
||||
|
||||
30
apps/hand-factory/components/klp-ui/k-form/k-form.vue
Normal file
30
apps/hand-factory/components/klp-ui/k-form/k-form.vue
Normal file
@@ -0,0 +1,30 @@
|
||||
<template>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
export default {
|
||||
props: {
|
||||
formConf: {
|
||||
require: true,
|
||||
type: Object
|
||||
},
|
||||
},
|
||||
watch: {
|
||||
formConf: {
|
||||
immediate: true,
|
||||
deep: true,
|
||||
handler(newVal) {
|
||||
this.SchemaToJsonForm(newVal)
|
||||
}
|
||||
}
|
||||
}
|
||||
methods: {
|
||||
SchemaToJsonForm(schema) {
|
||||
console.log(schema)
|
||||
}
|
||||
}
|
||||
}
|
||||
</script>
|
||||
|
||||
<style>
|
||||
</style>
|
||||
124
apps/hand-factory/components/klp-ui/k-info-card/k-info-card.vue
Normal file
124
apps/hand-factory/components/klp-ui/k-info-card/k-info-card.vue
Normal file
@@ -0,0 +1,124 @@
|
||||
<template>
|
||||
<view class="card-container" :style="{ borderRadius: borderRadius }">
|
||||
<!-- 头部区域 -->
|
||||
<view class="card-header" :style="headerStyle">
|
||||
<text class="header-title">{{ title }}</text>
|
||||
<text class="header-value">{{ value }}</text>
|
||||
</view>
|
||||
|
||||
<!-- 信息容器(条件渲染) -->
|
||||
<view v-if="info && info.length" class="info-container">
|
||||
<view v-for="(item, rowIndex) in info" :key="rowIndex" class="info-item">
|
||||
<text class="info-label">{{ item.label }}</text>
|
||||
<text class="info-value">
|
||||
{{ item.value }}
|
||||
<text v-if="item.unit" class="unit-text">{{ item.unit }}</text>
|
||||
</text>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
export default {
|
||||
name: 'DeviceInfoCard',
|
||||
props: {
|
||||
title: {
|
||||
type: String,
|
||||
required: true
|
||||
},
|
||||
value: {
|
||||
type: [String, Number],
|
||||
required: true
|
||||
},
|
||||
info: {
|
||||
type: Array,
|
||||
default: () => []
|
||||
},
|
||||
// 样式相关props
|
||||
borderRadius: {
|
||||
type: String,
|
||||
default: '10rpx'
|
||||
},
|
||||
headerStyle: {
|
||||
type: Object,
|
||||
default: () => ({
|
||||
backgroundColor: '#d9edf6',
|
||||
border: '1px solid #d9edf6'
|
||||
})
|
||||
},
|
||||
itemWidth: {
|
||||
type: String,
|
||||
default: '48%' // 控制信息项宽度
|
||||
}
|
||||
}
|
||||
}
|
||||
</script>
|
||||
|
||||
<style scoped>
|
||||
/* 卡片容器 */
|
||||
.card-container {
|
||||
overflow: hidden;
|
||||
background: #fff;
|
||||
box-shadow: 0 2rpx 12rpx rgba(0,0,0,0.05);
|
||||
}
|
||||
|
||||
/* 头部样式 */
|
||||
.card-header {
|
||||
display: flex;
|
||||
justify-content: space-between;
|
||||
align-items: center;
|
||||
padding: 20rpx;
|
||||
}
|
||||
|
||||
.header-title {
|
||||
font-size: 32rpx;
|
||||
color: #333;
|
||||
}
|
||||
|
||||
.header-value {
|
||||
font-size: 36rpx;
|
||||
color: #2a7ae9;
|
||||
font-weight: 500;
|
||||
}
|
||||
|
||||
/* 信息容器 */
|
||||
.info-container {
|
||||
padding: 20rpx;
|
||||
display: flex;
|
||||
box-sizing: border-box;
|
||||
flex-wrap: wrap;
|
||||
justify-content: space-between;
|
||||
}
|
||||
|
||||
.info-row {
|
||||
display: flex;
|
||||
justify-content: space-between;
|
||||
margin-bottom: 24rpx;
|
||||
}
|
||||
|
||||
.info-item {
|
||||
display: flex;
|
||||
align-items: baseline;
|
||||
}
|
||||
|
||||
.info-label {
|
||||
color: #666;
|
||||
font-size: 28rpx;
|
||||
flex-shrink: 0;
|
||||
margin-right: 16rpx;
|
||||
}
|
||||
|
||||
.info-value {
|
||||
color: #333;
|
||||
font-size: 30rpx;
|
||||
font-weight: 500;
|
||||
word-break: break-all;
|
||||
}
|
||||
|
||||
.unit-text {
|
||||
font-size: 0.8em;
|
||||
color: #999;
|
||||
margin-left: 6rpx;
|
||||
}
|
||||
</style>
|
||||
@@ -0,0 +1,68 @@
|
||||
<template>
|
||||
<view class="metric-container" :style="{ gridTemplateColumns: `repeat(${columns}, 1fr)` }">
|
||||
<view class="metric-item" v-for="(item, index) in items" :key="index">
|
||||
<view class="metric-value">
|
||||
{{ item.value }}
|
||||
</view>
|
||||
<view class="metric-label">{{ item.label }}</view>
|
||||
<view v-if="item.unit" class="metric-unit">{{ item.unit }}</view>
|
||||
</view>
|
||||
</view>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
export default {
|
||||
name: 'MetricCard',
|
||||
props: {
|
||||
items: {
|
||||
type: Array,
|
||||
required: true
|
||||
},
|
||||
columns: {
|
||||
type: Number,
|
||||
default: 3
|
||||
}
|
||||
}
|
||||
}
|
||||
</script>
|
||||
|
||||
<style scoped>
|
||||
.metric-container {
|
||||
display: grid;
|
||||
gap: 20rpx;
|
||||
padding: 20rpx;
|
||||
box-sizing: border-box;
|
||||
background-color: #fff;
|
||||
box-shadow: 0 4rpx 12rpx rgba(0,0,0,0.05);
|
||||
}
|
||||
|
||||
.metric-item {
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
justify-content: center;
|
||||
align-items: center;
|
||||
padding: 20rpx;
|
||||
}
|
||||
|
||||
.metric-value {
|
||||
font-size: 48rpx;
|
||||
font-weight: 600;
|
||||
margin-bottom: 16rpx;
|
||||
line-height: 1.2;
|
||||
color: #333;
|
||||
}
|
||||
|
||||
.metric-unit {
|
||||
font-size: 0.7em;
|
||||
color: #999;
|
||||
margin-left: 8rpx;
|
||||
}
|
||||
|
||||
.metric-label {
|
||||
font-size: 28rpx;
|
||||
color: #666;
|
||||
letter-spacing: 2rpx;
|
||||
text-align: center;
|
||||
line-height: 1.4;
|
||||
}
|
||||
</style>
|
||||
331
apps/hand-factory/components/klp-ui/k-table/k-table.vue
Normal file
331
apps/hand-factory/components/klp-ui/k-table/k-table.vue
Normal file
@@ -0,0 +1,331 @@
|
||||
<!-- components/uni-table/uni-table.vue -->
|
||||
<template>
|
||||
<view class="uni-table-container">
|
||||
<!-- 横向表格模式 -->
|
||||
<scroll-view
|
||||
v-if="mode === 'horizontal'"
|
||||
scroll-x
|
||||
class="horizontal-table"
|
||||
:style="{ maxHeight: height }"
|
||||
>
|
||||
<view class="table-header">
|
||||
<view
|
||||
v-for="(col, index) in columns"
|
||||
:key="index"
|
||||
class="header-cell"
|
||||
:style="getHeaderStyle(col)"
|
||||
>
|
||||
{{ col.title }}
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<view
|
||||
v-for="(row, rowIndex) in data"
|
||||
:key="rowIndex"
|
||||
class="table-row"
|
||||
:class="{ 'row-hover': rowHover }"
|
||||
@click="handleRowClick(row, rowIndex)"
|
||||
>
|
||||
<view
|
||||
v-for="(col, colIndex) in columns"
|
||||
:key="colIndex"
|
||||
class="body-cell"
|
||||
:style="getCellStyle(col)"
|
||||
>
|
||||
<slot
|
||||
v-if="col.slot"
|
||||
:name="col.slot"
|
||||
:row="row"
|
||||
:column="col"
|
||||
></slot>
|
||||
<text v-else>{{ formatCellValue(row[col.key], col) }}</text>
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<view v-if="data.length === 0" class="empty-tip">
|
||||
<u-empty mode="data" icon="/static/empty.png"/>
|
||||
</view>
|
||||
</scroll-view>
|
||||
|
||||
<!-- 纵向表格模式 -->
|
||||
<scroll-view
|
||||
v-else
|
||||
scroll-y
|
||||
class="vertical-table"
|
||||
:style="{ maxHeight: height }"
|
||||
>
|
||||
<view
|
||||
v-for="(row, rowIndex) in data"
|
||||
:key="rowIndex"
|
||||
class="vertical-row"
|
||||
:class="{ 'row-hover': rowHover }"
|
||||
@click="handleRowClick(row, rowIndex)"
|
||||
>
|
||||
<view
|
||||
v-for="(col, colIndex) in columns"
|
||||
:key="colIndex"
|
||||
class="vertical-cell"
|
||||
>
|
||||
<view class="cell-label">{{ col.title }}:</view>
|
||||
<view class="cell-value">
|
||||
<slot
|
||||
v-if="col.slot"
|
||||
:name="col.slot"
|
||||
:row="row"
|
||||
:column="col"
|
||||
></slot>
|
||||
<text v-else>{{ formatCellValue(row[col.key], col) }}</text>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<view v-if="data.length === 0" class="empty-tip">
|
||||
<u-empty mode="data" icon="/static/empty.png"/>
|
||||
</view>
|
||||
</scroll-view>
|
||||
</view>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
export default {
|
||||
name: 'UniTable',
|
||||
props: {
|
||||
// 表格模式:horizontal(横向)/vertical(纵向)
|
||||
mode: {
|
||||
type: String,
|
||||
default: 'horizontal',
|
||||
validator: value => ['horizontal', 'vertical'].includes(value)
|
||||
},
|
||||
// 列配置
|
||||
columns: {
|
||||
type: Array,
|
||||
required: true,
|
||||
},
|
||||
// 表格数据
|
||||
data: {
|
||||
type: Array,
|
||||
default: () => []
|
||||
},
|
||||
// 固定高度(支持px/rpx)
|
||||
height: {
|
||||
type: String,
|
||||
default: '1000rpx'
|
||||
},
|
||||
// 是否显示边框
|
||||
border: {
|
||||
type: Boolean,
|
||||
default: true
|
||||
},
|
||||
// 是否显示行hover效果
|
||||
rowHover: {
|
||||
type: Boolean,
|
||||
default: true
|
||||
},
|
||||
// 是否显示斑马纹
|
||||
stripe: {
|
||||
type: Boolean,
|
||||
default: false
|
||||
},
|
||||
// 是否显示序号列
|
||||
showIndex: {
|
||||
type: Boolean,
|
||||
default: false
|
||||
},
|
||||
// 序号列标题
|
||||
indexLabel: {
|
||||
type: String,
|
||||
default: '序号'
|
||||
}
|
||||
},
|
||||
|
||||
computed: {
|
||||
// 处理后的列配置
|
||||
processedColumns() {
|
||||
let cols = [...this.columns]
|
||||
if (this.showIndex) {
|
||||
cols.unshift({
|
||||
title: this.indexLabel,
|
||||
key: '_index',
|
||||
width: '80rpx',
|
||||
align: 'center'
|
||||
})
|
||||
}
|
||||
return cols
|
||||
}
|
||||
},
|
||||
|
||||
methods: {
|
||||
// 获取表头样式
|
||||
getHeaderStyle(col) {
|
||||
return {
|
||||
width: col.width || '200rpx',
|
||||
textAlign: col.align || 'left',
|
||||
flex: col.flex ? `0 0 ${col.width}` : 'none',
|
||||
backgroundColor: this.border ? '#f5f7fa' : 'transparent'
|
||||
}
|
||||
},
|
||||
|
||||
// 获取单元格样式
|
||||
getCellStyle(col) {
|
||||
return {
|
||||
width: col.width || '200rpx',
|
||||
textAlign: col.align || 'left',
|
||||
flex: col.flex ? `0 0 ${col.width}` : 'none'
|
||||
}
|
||||
},
|
||||
|
||||
// 行点击事件
|
||||
handleRowClick(row, index) {
|
||||
this.$emit('row-click', row, index)
|
||||
},
|
||||
|
||||
// 格式化单元格值
|
||||
formatCellValue(value, col) {
|
||||
if (value === undefined || value === null) {
|
||||
return '--'
|
||||
}
|
||||
|
||||
// 如果列定义了format函数,使用format函数处理
|
||||
if (col.format && typeof col.format === 'function') {
|
||||
return col.format(value)
|
||||
}
|
||||
|
||||
// 如果是日期类型
|
||||
if (col.type === 'date') {
|
||||
return this.formatDate(value, col.dateFormat)
|
||||
}
|
||||
|
||||
// 如果是数字类型
|
||||
if (col.type === 'number') {
|
||||
return this.formatNumber(value, col.precision)
|
||||
}
|
||||
|
||||
return value
|
||||
},
|
||||
|
||||
// 格式化日期
|
||||
formatDate(value, format = 'YYYY-MM-DD') {
|
||||
if (!value) return '--'
|
||||
// 这里可以使用日期格式化库,如dayjs
|
||||
return value
|
||||
},
|
||||
|
||||
// 格式化数字
|
||||
formatNumber(value, precision) {
|
||||
if (typeof value !== 'number') return value
|
||||
return precision !== undefined ? value.toFixed(precision) : value
|
||||
}
|
||||
}
|
||||
}
|
||||
</script>
|
||||
|
||||
<style lang="scss" scoped>
|
||||
.uni-table-container {
|
||||
background-color: #fff;
|
||||
border-radius: 12rpx;
|
||||
overflow: hidden;
|
||||
box-shadow: 0 2rpx 12rpx rgba(0, 0, 0, 0.1);
|
||||
|
||||
.horizontal-table {
|
||||
.table-header {
|
||||
display: flex;
|
||||
background-color: #f5f7fa;
|
||||
border-bottom: 2rpx solid #ebeef5;
|
||||
position: sticky;
|
||||
top: 0;
|
||||
z-index: 1;
|
||||
|
||||
.header-cell {
|
||||
padding: 24rpx;
|
||||
font-weight: 500;
|
||||
color: #303133;
|
||||
white-space: nowrap;
|
||||
transition: background-color 0.3s;
|
||||
position: relative;
|
||||
|
||||
&::after {
|
||||
content: '';
|
||||
position: absolute;
|
||||
right: 0;
|
||||
top: 50%;
|
||||
transform: translateY(-50%);
|
||||
height: 50%;
|
||||
width: 2rpx;
|
||||
background-color: #ebeef5;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
.table-row {
|
||||
display: flex;
|
||||
border-bottom: 1rpx solid #ebeef5;
|
||||
transition: background-color 0.3s;
|
||||
|
||||
&:last-child {
|
||||
border-bottom: none;
|
||||
}
|
||||
|
||||
&.row-hover:active {
|
||||
background-color: #f5f7fa;
|
||||
}
|
||||
|
||||
.body-cell {
|
||||
padding: 24rpx;
|
||||
color: #606266;
|
||||
word-break: break-all;
|
||||
display: flex;
|
||||
align-items: center;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
.vertical-table {
|
||||
.vertical-row {
|
||||
padding: 24rpx;
|
||||
border-bottom: 1rpx solid #ebeef5;
|
||||
transition: background-color 0.3s;
|
||||
|
||||
&:last-child {
|
||||
border-bottom: none;
|
||||
}
|
||||
|
||||
&.row-hover:active {
|
||||
background-color: #f5f7fa;
|
||||
}
|
||||
|
||||
.vertical-cell {
|
||||
display: flex;
|
||||
margin-bottom: 20rpx;
|
||||
align-items: flex-start;
|
||||
|
||||
&:last-child {
|
||||
margin-bottom: 0;
|
||||
}
|
||||
|
||||
.cell-label {
|
||||
width: 200rpx;
|
||||
color: #909399;
|
||||
flex-shrink: 0;
|
||||
font-size: 28rpx;
|
||||
}
|
||||
|
||||
.cell-value {
|
||||
flex: 1;
|
||||
color: #303133;
|
||||
word-break: break-all;
|
||||
font-size: 28rpx;
|
||||
padding-left: 20rpx;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
.empty-tip {
|
||||
padding: 80rpx 0;
|
||||
display: flex;
|
||||
justify-content: center;
|
||||
align-items: center;
|
||||
background-color: #fff;
|
||||
}
|
||||
}
|
||||
</style>
|
||||
325
apps/hand-factory/components/lines/acidity.vue
Normal file
325
apps/hand-factory/components/lines/acidity.vue
Normal file
@@ -0,0 +1,325 @@
|
||||
<template>
|
||||
<view>
|
||||
<view class="tab">
|
||||
<uni-data-checkbox
|
||||
mode="tag"
|
||||
selectedColor="#2bf"
|
||||
v-model="currentTab"
|
||||
:localdata="tabData"
|
||||
></uni-data-checkbox>
|
||||
</view>
|
||||
|
||||
<scroll-view scroll-y v-if="currentTab === 1">
|
||||
<view class="content-card">
|
||||
<k-metric-card
|
||||
:items="webStatus"
|
||||
:columns="2"
|
||||
></k-metric-card>
|
||||
</view>
|
||||
|
||||
<view class="content-card">
|
||||
<k-collapse-panel title="状态统计">
|
||||
<template #extra>
|
||||
<view class="filter-btn" @click="openTimePicker">
|
||||
<uni-icons type="calendar" size="16" color="white"></uni-icons>
|
||||
<text class="filter-text">{{ timeRange }}</text>
|
||||
</view>
|
||||
</template>
|
||||
<qiun-data-charts type="line" :chartData="chartData" />
|
||||
</k-collapse-panel>
|
||||
</view>
|
||||
|
||||
<view class="content-card">
|
||||
<k-collapse-panel title="轧机状态">
|
||||
<qiun-data-charts type="column" :chartData="chartData" />
|
||||
</k-collapse-panel>
|
||||
</view>
|
||||
|
||||
<view class="content-card">
|
||||
<k-collapse-panel title="机组跟踪">
|
||||
<view style="padding: 30rpx; display: flex; flex-direction: column; align-items: stretch; justify-content: center; gap: 20rpx;">
|
||||
<k-info-card
|
||||
v-for="(item, index) in crewTracking"
|
||||
:key="index"
|
||||
:title="item.title"
|
||||
:value="item.value"
|
||||
:info="item.info"
|
||||
></k-info-card>
|
||||
</view>
|
||||
</k-collapse-panel>
|
||||
</view>
|
||||
|
||||
<view class="content-card">
|
||||
<k-collapse-panel title="能耗">
|
||||
<k-metric-card
|
||||
:items="energyStatus"
|
||||
:columus="3"
|
||||
></k-metric-card>
|
||||
</k-collapse-panel>
|
||||
</view>
|
||||
</scroll-view>
|
||||
|
||||
<scroll-view scroll-y v-if="currentTab == 2">
|
||||
<klp-product-statistic></klp-product-statistic>
|
||||
</scroll-view>
|
||||
|
||||
<scroll-view scroll-y v-if="currentTab == 3">
|
||||
<klp-shutdown-statistic></klp-shutdown-statistic>
|
||||
</scroll-view>
|
||||
|
||||
<scroll-view scroll-y v-if="currentTab == 4">
|
||||
<klp-team-performance></klp-team-performance>
|
||||
</scroll-view>
|
||||
|
||||
<!-- 时间选择弹出层 -->
|
||||
<uni-popup ref="timePickerPopup" type="bottom" background-color="#fff" @change="popupChange">
|
||||
<view class="popup-content">
|
||||
<view class="popup-header">
|
||||
<text class="popup-title">选择时间范围</text>
|
||||
<view class="popup-close" @click="closeTimePicker">
|
||||
<uni-icons type="close" size="20" color="#666"></uni-icons>
|
||||
</view>
|
||||
</view>
|
||||
<view class="time-picker-container">
|
||||
<uni-datetime-picker
|
||||
type="datetimerange"
|
||||
v-model="selectedTimeRange"
|
||||
@change="onTimeRangeChange"
|
||||
start="2020-01-01 00:00:00"
|
||||
end="2025-12-31 23:59:59"
|
||||
/>
|
||||
</view>
|
||||
</view>
|
||||
</uni-popup>
|
||||
</view>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
export default {
|
||||
data() {
|
||||
return {
|
||||
currentTab: 1,
|
||||
tabData: [
|
||||
{
|
||||
text: "实时监控",
|
||||
value: 1,
|
||||
},
|
||||
{
|
||||
text: "生产统计",
|
||||
value: 2,
|
||||
},
|
||||
{
|
||||
text: "停机统计",
|
||||
value: 3,
|
||||
},
|
||||
{
|
||||
text: "班组绩效",
|
||||
value: 4,
|
||||
},
|
||||
],
|
||||
chartData: {},
|
||||
webStatus: [
|
||||
{ label: '网络状态', value: '正常' },
|
||||
{ label: '当前班组', value: '乙 / 中' }
|
||||
],
|
||||
energyStatus: [
|
||||
{ label: '工艺缎带钢线速度', value: '9.9' },
|
||||
{ label: '轧机出口带钢线速度', value: '126.0' }
|
||||
],
|
||||
crewTracking: [
|
||||
{
|
||||
title: '轧机',
|
||||
value: 6390000
|
||||
},
|
||||
{
|
||||
title: '圆剪盘',
|
||||
value: 6390000,
|
||||
info: [
|
||||
{ label: '设备编号', value: 'A-01' },
|
||||
{ label: '运行状态', value: '正常' },
|
||||
{ label: '当前产量', value: 2500, unit: '件' },
|
||||
{ label: '合格率', value: '100%' }
|
||||
]
|
||||
},
|
||||
{
|
||||
title: '酸洗',
|
||||
value: 6390000,
|
||||
},
|
||||
{
|
||||
title: '入口活套',
|
||||
value: 6390000,
|
||||
info: [
|
||||
{ label: '设备编号', value: 'A-01' },
|
||||
{ label: '运行状态', value: '正常' },
|
||||
{ label: '当前产量', value: 2500, unit: '件' },
|
||||
{ label: '合格率', value: '100%' }
|
||||
]
|
||||
}
|
||||
],
|
||||
selectedTimeRange: []
|
||||
};
|
||||
},
|
||||
computed: {
|
||||
timeRange() {
|
||||
if (!this.selectedTimeRange || this.selectedTimeRange.length !== 2) {
|
||||
return '选择时间';
|
||||
}
|
||||
const start = new Date(this.selectedTimeRange[0]).toLocaleDateString('zh-CN');
|
||||
const end = new Date(this.selectedTimeRange[1]).toLocaleDateString('zh-CN');
|
||||
return `${start} - ${end}`;
|
||||
}
|
||||
},
|
||||
mounted() {
|
||||
this.getServerData();
|
||||
},
|
||||
methods: {
|
||||
getServerData() {
|
||||
// 模拟从服务器获取数据时的延时
|
||||
uni.showLoading({
|
||||
title: '加载中'
|
||||
});
|
||||
|
||||
setTimeout(() => {
|
||||
let res = {
|
||||
categories: ['2016', '2017', '2018', '2019', '2020', '2021'],
|
||||
series: [
|
||||
{
|
||||
name: '目标值',
|
||||
data: [35, 36, 31, 33, 13, 34],
|
||||
},
|
||||
{
|
||||
name: '完成量',
|
||||
data: [18, 27, 21, 24, 6, 28],
|
||||
},
|
||||
],
|
||||
};
|
||||
this.chartData = JSON.parse(JSON.stringify(res));
|
||||
uni.hideLoading();
|
||||
}, 500);
|
||||
},
|
||||
openTimePicker() {
|
||||
this.$refs.timePickerPopup.open();
|
||||
uni.showLoading({
|
||||
title: '加载中'
|
||||
});
|
||||
// 模拟数据加载
|
||||
setTimeout(() => {
|
||||
uni.hideLoading();
|
||||
}, 500);
|
||||
},
|
||||
closeTimePicker() {
|
||||
this.$refs.timePickerPopup.close();
|
||||
},
|
||||
popupChange(e) {
|
||||
if (e.show === false) {
|
||||
// 弹窗关闭时的处理
|
||||
}
|
||||
},
|
||||
onTimeRangeChange(e) {
|
||||
if (!e) return;
|
||||
this.selectedTimeRange = e;
|
||||
this.closeTimePicker();
|
||||
// 这里可以调用接口重新获取数据
|
||||
this.getServerData();
|
||||
}
|
||||
}
|
||||
};
|
||||
</script>
|
||||
|
||||
<style scoped lang="scss">
|
||||
view-scroll {
|
||||
gap: 30rpx;
|
||||
}
|
||||
|
||||
.tab {
|
||||
margin: auto;
|
||||
display: flex;
|
||||
box-sizing: border-box;
|
||||
justify-content: center;
|
||||
position: sticky;
|
||||
top: 88rpx;
|
||||
z-index: 999;
|
||||
background-color: #fff;
|
||||
}
|
||||
|
||||
.content-card {
|
||||
background-color: white;
|
||||
}
|
||||
|
||||
/** */
|
||||
.info-container {
|
||||
padding: 20rpx;
|
||||
background: #fff;
|
||||
border-radius: 12rpx;
|
||||
}
|
||||
|
||||
.info-row {
|
||||
display: flex;
|
||||
justify-content: space-between;
|
||||
margin-bottom: 24rpx;
|
||||
|
||||
&:last-child {
|
||||
margin-bottom: 0;
|
||||
}
|
||||
}
|
||||
|
||||
.info-item {
|
||||
flex: 0 0 48%; /* 留出4%的间隔 */
|
||||
display: flex;
|
||||
align-items: baseline; /* 文字基线对齐 */
|
||||
}
|
||||
|
||||
.info-label {
|
||||
color: #666;
|
||||
font-size: 28rpx;
|
||||
flex-shrink: 0;
|
||||
margin-right: 16rpx;
|
||||
}
|
||||
|
||||
.info-value {
|
||||
color: #333;
|
||||
font-size: 30rpx;
|
||||
font-weight: 500;
|
||||
word-break: break-all; /* 长文本自动换行 */
|
||||
}
|
||||
|
||||
.filter-btn {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
gap: 8rpx;
|
||||
padding: 8rpx 16rpx;
|
||||
background: rgba(255, 255, 255, 0.2);
|
||||
border-radius: 4rpx;
|
||||
|
||||
.filter-text {
|
||||
font-size: 24rpx;
|
||||
color: white;
|
||||
}
|
||||
}
|
||||
|
||||
.popup-content {
|
||||
background-color: #fff;
|
||||
border-radius: 24rpx 24rpx 0 0;
|
||||
padding: 32rpx;
|
||||
|
||||
.popup-header {
|
||||
display: flex;
|
||||
justify-content: space-between;
|
||||
align-items: center;
|
||||
margin-bottom: 32rpx;
|
||||
|
||||
.popup-title {
|
||||
font-size: 32rpx;
|
||||
font-weight: 500;
|
||||
}
|
||||
|
||||
.popup-close {
|
||||
padding: 8rpx;
|
||||
}
|
||||
}
|
||||
|
||||
.time-picker-container {
|
||||
padding: 16rpx 0;
|
||||
}
|
||||
}
|
||||
</style>
|
||||
280
apps/hand-factory/components/lines/paint.vue
Normal file
280
apps/hand-factory/components/lines/paint.vue
Normal file
@@ -0,0 +1,280 @@
|
||||
<template>
|
||||
<view>
|
||||
<view class="tab">
|
||||
<uni-data-checkbox
|
||||
mode="tag"
|
||||
selectedColor="#2bf"
|
||||
v-model="currentTab"
|
||||
:localdata="tabData"
|
||||
></uni-data-checkbox>
|
||||
</view>
|
||||
|
||||
<scroll-view scroll-y v-if="currentTab === 1">
|
||||
<view class="content-card">
|
||||
<k-metric-card
|
||||
:items="status"
|
||||
:columns="2"
|
||||
></k-metric-card>
|
||||
</view>
|
||||
|
||||
<view class="content-card">
|
||||
<klp-collapse-panel title="状态统计">
|
||||
<qiun-data-charts type="line" :chartData="chartData" />
|
||||
</klp-collapse-panel>
|
||||
</view>
|
||||
|
||||
<view class="content-card">
|
||||
<klp-collapse-panel title="轧机状态">
|
||||
<qiun-data-charts type="column" :chartData="chartData" />
|
||||
</klp-collapse-panel>
|
||||
</view>
|
||||
|
||||
<view class="content-card">
|
||||
<klp-collapse-panel title="机组跟踪">
|
||||
<view style="padding: 30rpx; display: flex; flex-direction: column; align-items: stretch; justify-content: center; gap: 20rpx;">
|
||||
<view style="display: flex; justify-content: space-between; align-items: center; padding: 20rpx; background-color: #d9edf6; border-radius: 10rpx;">
|
||||
<text>轧机</text>
|
||||
<text>6390000</text>
|
||||
</view>
|
||||
|
||||
<view style="border-radius: 10rpx; overflow: hidden;">
|
||||
<view style="display: flex; justify-content: space-between; align-items: center; padding: 20rpx; background-color: #d9edf6; border: 1px solid #d9edf6;">
|
||||
<text>圆剪盘</text>
|
||||
<text>6390000</text>
|
||||
</view>
|
||||
<view class="info-container">
|
||||
<view class="info-row">
|
||||
<view class="info-item">
|
||||
<text class="info-label">设备编号:</text>
|
||||
<text class="info-value">M-001</text>
|
||||
</view>
|
||||
<view class="info-item">
|
||||
<text class="info-label">运行状态:</text>
|
||||
<text class="info-value">正常</text>
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<view class="info-row">
|
||||
<view class="info-item">
|
||||
<text class="info-label">当前产量:</text>
|
||||
<text class="info-value">2580 件</text>
|
||||
</view>
|
||||
<view class="info-item">
|
||||
<text class="info-label">合格率:</text>
|
||||
<text class="info-value">98.5%</text>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<view style="display: flex; justify-content: space-between; align-items: center; padding: 20rpx; background-color: #d9edf6; border-radius: 10rpx;">
|
||||
<text>酸洗</text>
|
||||
<text>6390000</text>
|
||||
</view>
|
||||
|
||||
<view style="border-radius: 10rpx; overflow: hidden;">
|
||||
<view style="display: flex; justify-content: space-between; align-items: center; padding: 20rpx; background-color: #d9edf6; border: 1px solid #d9edf6;">
|
||||
<text>入口活套</text>
|
||||
<text>6390000</text>
|
||||
</view>
|
||||
<view class="info-container">
|
||||
<view class="info-row">
|
||||
<view class="info-item">
|
||||
<text class="info-label">设备编号:</text>
|
||||
<text class="info-value">M-001</text>
|
||||
</view>
|
||||
<view class="info-item">
|
||||
<text class="info-label">运行状态:</text>
|
||||
<text class="info-value">正常</text>
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<view class="info-row">
|
||||
<view class="info-item">
|
||||
<text class="info-label">当前产量:</text>
|
||||
<text class="info-value">2580 件</text>
|
||||
</view>
|
||||
<view class="info-item">
|
||||
<text class="info-label">合格率:</text>
|
||||
<text class="info-value">98.5%</text>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
</klp-collapse-panel>
|
||||
</view>
|
||||
|
||||
<view class="content-card">
|
||||
<klp-collapse-panel title="能耗">
|
||||
<view class="metric-container">
|
||||
<!-- 网络状态指标 -->
|
||||
<view class="metric-item">
|
||||
<view class="metric-value">
|
||||
9.9
|
||||
</view>
|
||||
<view class="metric-label">
|
||||
工艺缎带钢线速度
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<!-- 班组指标 -->
|
||||
<view class="metric-item">
|
||||
<view class="metric-value team-number">
|
||||
126.0
|
||||
</view>
|
||||
<view class="metric-label">
|
||||
轧机出口带钢线速度
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
</klp-collapse-panel>
|
||||
</view>
|
||||
</scroll-view>
|
||||
|
||||
<scroll-view scroll-y v-if="currentTab == 2">
|
||||
<klp-product-statistic></klp-product-statistic>
|
||||
</scroll-view>
|
||||
|
||||
<scroll-view scroll-y v-if="currentTab == 3">
|
||||
<klp-shutdown-statistic></klp-shutdown-statistic>
|
||||
</scroll-view>
|
||||
|
||||
<scroll-view scroll-y v-if="currentTab == 4">
|
||||
<klp-team-performance></klp-team-performance>
|
||||
</scroll-view>
|
||||
</view>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
export default {
|
||||
// 响应式数据(替代 Vue 3 的 ref)
|
||||
data() {
|
||||
return {
|
||||
currentTab: 1, // 当前选中的标签页
|
||||
tabData: [
|
||||
{ text: "实时监控", value: 1 },
|
||||
{ text: "生产统计", value: 2 },
|
||||
{ text: "停机统计", value: 3 },
|
||||
{ text: "班组绩效", value: 4 }
|
||||
],
|
||||
status: [ // 状态指标数据(供 k-metric-card 使用)
|
||||
{ label: '网络状态', value: '正常' },
|
||||
{ label: '当前班组', value: '乙 / 中' }
|
||||
],
|
||||
chartData: {} // 图表数据(初始化空对象)
|
||||
}
|
||||
},
|
||||
// 生命周期钩子(替代 Vue 3 的 onMounted)
|
||||
mounted() {
|
||||
this.getServerData() // 页面挂载后加载数据
|
||||
},
|
||||
// 方法定义(所有函数需放在 methods 中)
|
||||
methods: {
|
||||
// 模拟从服务器获取数据
|
||||
getServerData() {
|
||||
setTimeout(() => {
|
||||
const res = {
|
||||
categories: ['2016', '2017', '2018', '2019', '2020', '2021'],
|
||||
series: [
|
||||
{ name: '目标值', data: [35, 36, 31, 33, 13, 34] },
|
||||
{ name: '完成量', data: [18, 27, 21, 24, 6, 28] }
|
||||
]
|
||||
}
|
||||
// 深拷贝避免引用问题(Vue 2 响应式兼容)
|
||||
this.chartData = JSON.parse(JSON.stringify(res))
|
||||
}, 500)
|
||||
}
|
||||
}
|
||||
}
|
||||
</script>
|
||||
|
||||
<style scoped lang="scss">
|
||||
page {
|
||||
background-color: #b2b2b2;
|
||||
height: 100vh;
|
||||
overflow: auto;
|
||||
}
|
||||
|
||||
view-scroll {
|
||||
gap: 30rpx;
|
||||
}
|
||||
|
||||
.tab {
|
||||
margin: auto;
|
||||
display: flex;
|
||||
box-sizing: border-box;
|
||||
justify-content: center;
|
||||
top: 88rpx;
|
||||
z-index: 999;
|
||||
background-color: #fff;
|
||||
}
|
||||
|
||||
.content-card {
|
||||
background-color: white;
|
||||
}
|
||||
|
||||
.metric-container {
|
||||
display: flex;
|
||||
justify-content: space-around;
|
||||
background-color: white;
|
||||
}
|
||||
|
||||
.metric-item {
|
||||
flex: 1;
|
||||
text-align: center;
|
||||
padding: 32rpx;
|
||||
border-radius: 12rpx;
|
||||
transition: all 0.3s;
|
||||
}
|
||||
|
||||
.metric-value {
|
||||
font-size: 48rpx;
|
||||
font-weight: 600;
|
||||
margin-bottom: 16rpx;
|
||||
line-height: 1.2;
|
||||
}
|
||||
|
||||
.metric-label {
|
||||
font-size: 28rpx;
|
||||
color: #666;
|
||||
letter-spacing: 2rpx;
|
||||
}
|
||||
|
||||
/** 机组跟踪信息容器样式 */
|
||||
.info-container {
|
||||
padding: 20rpx;
|
||||
background: #fff;
|
||||
border-radius: 12rpx;
|
||||
}
|
||||
|
||||
.info-row {
|
||||
display: flex;
|
||||
justify-content: space-between;
|
||||
margin-bottom: 24rpx;
|
||||
|
||||
&:last-child {
|
||||
margin-bottom: 0;
|
||||
}
|
||||
}
|
||||
|
||||
.info-item {
|
||||
flex: 0 0 48%; /* 留出4%的间隔,避免内容溢出 */
|
||||
display: flex;
|
||||
align-items: baseline; /* 文字基线对齐,保证排版整齐 */
|
||||
}
|
||||
|
||||
.info-label {
|
||||
color: #666;
|
||||
font-size: 28rpx;
|
||||
flex-shrink: 0;
|
||||
margin-right: 16rpx;
|
||||
}
|
||||
|
||||
.info-value {
|
||||
color: #333;
|
||||
font-size: 30rpx;
|
||||
font-weight: 500;
|
||||
word-break: break-all; /* 长文本自动换行,防止超出容器 */
|
||||
}
|
||||
</style>
|
||||
313
apps/hand-factory/components/lines/zinc1.vue
Normal file
313
apps/hand-factory/components/lines/zinc1.vue
Normal file
@@ -0,0 +1,313 @@
|
||||
<template>
|
||||
<view>
|
||||
<view class="tab">
|
||||
<uni-data-checkbox
|
||||
mode="tag"
|
||||
selectedColor="#2bf"
|
||||
v-model="currentTab"
|
||||
:localdata="tabData"
|
||||
></uni-data-checkbox>
|
||||
</view>
|
||||
|
||||
<scroll-view scroll-y v-if="currentTab === 1">
|
||||
<view class="content-card">
|
||||
<view class="metric-container">
|
||||
<!-- 网络状态指标 -->
|
||||
<view class="metric-item">
|
||||
<view class="metric-value">
|
||||
正常
|
||||
</view>
|
||||
<view class="metric-label">
|
||||
网络状态
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<!-- 班组指标 -->
|
||||
<view class="metric-item">
|
||||
<view class="metric-value team-number">
|
||||
乙 / 中
|
||||
</view>
|
||||
<view class="metric-label">
|
||||
当前班组
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<view class="content-card">
|
||||
<klp-collapse-panel title="状态统计">
|
||||
<qiun-data-charts type="line" :chartData="chartData" />
|
||||
</klp-collapse-panel>
|
||||
</view>
|
||||
|
||||
<view class="content-card">
|
||||
<klp-collapse-panel title="轧机状态">
|
||||
<qiun-data-charts type="column" :chartData="chartData" />
|
||||
</klp-collapse-panel>
|
||||
</view>
|
||||
|
||||
<view class="content-card">
|
||||
<klp-collapse-panel title="机组跟踪">
|
||||
<view style="padding: 30rpx; display: flex; flex-direction: column; align-items: stretch; justify-content: center; gap: 20rpx;">
|
||||
<view style="display: flex; justify-content: space-between; align-items: center; padding: 20rpx; background-color: #d9edf6; border-radius: 10rpx;">
|
||||
<text>轧机</text>
|
||||
<text>6390000</text>
|
||||
</view>
|
||||
|
||||
<view style="border-radius: 10rpx; overflow: hidden;">
|
||||
<view style="display: flex; justify-content: space-between; align-items: center; padding: 20rpx; background-color: #d9edf6; border: 1px solid #d9edf6;">
|
||||
<text>圆剪盘</text>
|
||||
<text>6390000</text>
|
||||
</view>
|
||||
<view class="info-container">
|
||||
<view class="info-row">
|
||||
<view class="info-item">
|
||||
<text class="info-label">设备编号:</text>
|
||||
<text class="info-value">M-001</text>
|
||||
</view>
|
||||
<view class="info-item">
|
||||
<text class="info-label">运行状态:</text>
|
||||
<text class="info-value">正常</text>
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<view class="info-row">
|
||||
<view class="info-item">
|
||||
<text class="info-label">当前产量:</text>
|
||||
<text class="info-value">2580 件</text>
|
||||
</view>
|
||||
<view class="info-item">
|
||||
<text class="info-label">合格率:</text>
|
||||
<text class="info-value">98.5%</text>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<view style="display: flex; justify-content: space-between; align-items: center; padding: 20rpx; background-color: #d9edf6; border-radius: 10rpx;">
|
||||
<text>酸洗</text>
|
||||
<text>6390000</text>
|
||||
</view>
|
||||
|
||||
<view style="border-radius: 10rpx; overflow: hidden;">
|
||||
<view style="display: flex; justify-content: space-between; align-items: center; padding: 20rpx; background-color: #d9edf6; border: 1px solid #d9edf6;">
|
||||
<text>入口活套</text>
|
||||
<text>6390000</text>
|
||||
</view>
|
||||
<view class="info-container">
|
||||
<view class="info-row">
|
||||
<view class="info-item">
|
||||
<text class="info-label">设备编号:</text>
|
||||
<text class="info-value">M-001</text>
|
||||
</view>
|
||||
<view class="info-item">
|
||||
<text class="info-label">运行状态:</text>
|
||||
<text class="info-value">正常</text>
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<view class="info-row">
|
||||
<view class="info-item">
|
||||
<text class="info-label">当前产量:</text>
|
||||
<text class="info-value">2580 件</text>
|
||||
</view>
|
||||
<view class="info-item">
|
||||
<text class="info-label">合格率:</text>
|
||||
<text class="info-value">98.5%</text>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
</klp-collapse-panel>
|
||||
</view>
|
||||
|
||||
<view class="content-card">
|
||||
<klp-collapse-panel title="能耗">
|
||||
<view class="metric-container">
|
||||
<!-- 工艺线速度指标 -->
|
||||
<view class="metric-item">
|
||||
<view class="metric-value">
|
||||
9.9
|
||||
</view>
|
||||
<view class="metric-label">
|
||||
工艺缎带钢线速度
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<!-- 出口线速度指标 -->
|
||||
<view class="metric-item">
|
||||
<view class="metric-value team-number">
|
||||
126.0
|
||||
</view>
|
||||
<view class="metric-label">
|
||||
轧机出口带钢线速度
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
</klp-collapse-panel>
|
||||
</view>
|
||||
</scroll-view>
|
||||
|
||||
<scroll-view scroll-y v-if="currentTab == 2">
|
||||
<klp-product-statistic></klp-product-statistic>
|
||||
</scroll-view>
|
||||
|
||||
<scroll-view scroll-y v-if="currentTab == 3">
|
||||
<klp-shutdown-statistic></klp-shutdown-statistic>
|
||||
</scroll-view>
|
||||
|
||||
<scroll-view scroll-y v-if="currentTab == 4">
|
||||
<klp-team-performance></klp-team-performance>
|
||||
</scroll-view>
|
||||
</view>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
export default {
|
||||
// 3. 响应式数据(替代 Vue 3 的 ref)
|
||||
data() {
|
||||
return {
|
||||
currentTab: 1, // 当前激活的标签页(默认实时监控)
|
||||
tabData: [ // 标签页配置
|
||||
{ text: "实时监控", value: 1 },
|
||||
{ text: "生产统计", value: 2 },
|
||||
{ text: "停机统计", value: 3 },
|
||||
{ text: "班组绩效", value: 4 }
|
||||
],
|
||||
chartData: {} // 图表数据(初始化空对象,后续加载)
|
||||
};
|
||||
},
|
||||
// 4. 生命周期钩子(替代 Vue 3 的 onMounted)
|
||||
mounted() {
|
||||
this.getServerData(); // 页面挂载后加载图表数据
|
||||
},
|
||||
// 5. 方法定义(所有数据处理与逻辑)
|
||||
methods: {
|
||||
// 模拟从服务器获取图表数据
|
||||
getServerData() {
|
||||
setTimeout(() => {
|
||||
// 模拟服务器返回的图表数据
|
||||
const serverRes = {
|
||||
categories: ["2016", "2017", "2018", "2019", "2020", "2021"],
|
||||
series: [
|
||||
{ name: "目标值", data: [35, 36, 31, 33, 13, 34] },
|
||||
{ name: "完成量", data: [18, 27, 21, 24, 6, 28] }
|
||||
]
|
||||
};
|
||||
// 深拷贝避免 Vue 2 响应式引用问题
|
||||
this.chartData = JSON.parse(JSON.stringify(serverRes));
|
||||
}, 500);
|
||||
}
|
||||
}
|
||||
};
|
||||
</script>
|
||||
|
||||
<style scoped lang="scss">
|
||||
page {
|
||||
background-color: #b2b2b2;
|
||||
height: 100vh;
|
||||
overflow: auto;
|
||||
}
|
||||
|
||||
/* 滚动视图间隙(原代码选择器可能笔误,保留原逻辑) */
|
||||
view-scroll {
|
||||
gap: 30rpx;
|
||||
}
|
||||
|
||||
/* 标签页容器样式 */
|
||||
.tab {
|
||||
margin: auto;
|
||||
display: flex;
|
||||
box-sizing: border-box;
|
||||
justify-content: center;
|
||||
top: 88rpx; /* 需配合 position: sticky 生效,原代码未加,可根据需求补充 */
|
||||
position: sticky; /* 补充粘性定位,确保标签页滚动时固定在顶部 */
|
||||
z-index: 999;
|
||||
background-color: #fff;
|
||||
padding: 10rpx 0; /* 补充内边距,优化点击体验 */
|
||||
}
|
||||
|
||||
/* 内容卡片样式 */
|
||||
.content-card {
|
||||
border-radius: 16rpx; /* 补充圆角,与设计风格统一 */
|
||||
overflow: hidden; /* 防止内部内容溢出卡片 */
|
||||
}
|
||||
|
||||
/* 指标容器样式 */
|
||||
.metric-container {
|
||||
display: flex;
|
||||
justify-content: space-around;
|
||||
background-color: white;
|
||||
padding: 20rpx 0;
|
||||
}
|
||||
|
||||
/* 单个指标项样式 */
|
||||
.metric-item {
|
||||
flex: 1;
|
||||
text-align: center;
|
||||
padding: 32rpx;
|
||||
border-radius: 12rpx;
|
||||
transition: all 0.3s;
|
||||
margin: 0 10rpx; /* 补充左右间距,避免指标过挤 */
|
||||
background-color: #f8f9fa; /* 补充背景色,区分指标区域 */
|
||||
}
|
||||
|
||||
/* 指标数值样式 */
|
||||
.metric-value {
|
||||
font-size: 48rpx;
|
||||
font-weight: 600;
|
||||
margin-bottom: 16rpx;
|
||||
line-height: 1.2;
|
||||
color: #333;
|
||||
}
|
||||
|
||||
/* 指标标签样式 */
|
||||
.metric-label {
|
||||
font-size: 28rpx;
|
||||
color: #666;
|
||||
letter-spacing: 2rpx;
|
||||
}
|
||||
|
||||
/* 机组跟踪信息容器 */
|
||||
.info-container {
|
||||
padding: 20rpx;
|
||||
background: #fff;
|
||||
border-radius: 12rpx;
|
||||
border-top: 1px solid #eee; /* 补充上边框,区分标题与内容 */
|
||||
}
|
||||
|
||||
/* 信息行样式 */
|
||||
.info-row {
|
||||
display: flex;
|
||||
justify-content: space-between;
|
||||
margin-bottom: 24rpx;
|
||||
|
||||
&:last-child {
|
||||
margin-bottom: 0;
|
||||
}
|
||||
}
|
||||
|
||||
/* 单个信息项样式 */
|
||||
.info-item {
|
||||
flex: 0 0 48%; /* 留出4%的间隔,避免内容溢出 */
|
||||
display: flex;
|
||||
align-items: baseline; /* 文字基线对齐,排版更整齐 */
|
||||
}
|
||||
|
||||
/* 信息标签样式 */
|
||||
.info-label {
|
||||
color: #666;
|
||||
font-size: 28rpx;
|
||||
flex-shrink: 0;
|
||||
margin-right: 16rpx;
|
||||
}
|
||||
|
||||
/* 信息数值样式 */
|
||||
.info-value {
|
||||
color: #333;
|
||||
font-size: 30rpx;
|
||||
font-weight: 500;
|
||||
word-break: break-all; /* 长文本自动换行,防止超出容器 */
|
||||
}
|
||||
</style>
|
||||
313
apps/hand-factory/components/lines/zinc2.vue
Normal file
313
apps/hand-factory/components/lines/zinc2.vue
Normal file
@@ -0,0 +1,313 @@
|
||||
<template>
|
||||
<view>
|
||||
<view class="tab">
|
||||
<uni-data-checkbox
|
||||
mode="tag"
|
||||
selectedColor="#2bf"
|
||||
v-model="currentTab"
|
||||
:localdata="tabData"
|
||||
></uni-data-checkbox>
|
||||
</view>
|
||||
|
||||
<scroll-view scroll-y v-if="currentTab === 1">
|
||||
<view class="content-card">
|
||||
<view class="metric-container">
|
||||
<!-- 网络状态指标 -->
|
||||
<view class="metric-item">
|
||||
<view class="metric-value">
|
||||
正常
|
||||
</view>
|
||||
<view class="metric-label">
|
||||
网络状态
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<!-- 班组指标 -->
|
||||
<view class="metric-item">
|
||||
<view class="metric-value team-number">
|
||||
乙 / 中
|
||||
</view>
|
||||
<view class="metric-label">
|
||||
当前班组
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<view class="content-card">
|
||||
<klp-collapse-panel title="状态统计">
|
||||
<qiun-data-charts type="line" :chartData="chartData" />
|
||||
</klp-collapse-panel>
|
||||
</view>
|
||||
|
||||
<view class="content-card">
|
||||
<klp-collapse-panel title="轧机状态">
|
||||
<qiun-data-charts type="column" :chartData="chartData" />
|
||||
</klp-collapse-panel>
|
||||
</view>
|
||||
|
||||
<view class="content-card">
|
||||
<klp-collapse-panel title="机组跟踪">
|
||||
<view style="padding: 30rpx; display: flex; flex-direction: column; align-items: stretch; justify-content: center; gap: 20rpx;">
|
||||
<view style="display: flex; justify-content: space-between; align-items: center; padding: 20rpx; background-color: #d9edf6; border-radius: 10rpx;">
|
||||
<text>轧机</text>
|
||||
<text>6390000</text>
|
||||
</view>
|
||||
|
||||
<view style="border-radius: 10rpx; overflow: hidden;">
|
||||
<view style="display: flex; justify-content: space-between; align-items: center; padding: 20rpx; background-color: #d9edf6; border: 1px solid #d9edf6;">
|
||||
<text>圆剪盘</text>
|
||||
<text>6390000</text>
|
||||
</view>
|
||||
<view class="info-container">
|
||||
<view class="info-row">
|
||||
<view class="info-item">
|
||||
<text class="info-label">设备编号:</text>
|
||||
<text class="info-value">M-001</text>
|
||||
</view>
|
||||
<view class="info-item">
|
||||
<text class="info-label">运行状态:</text>
|
||||
<text class="info-value">正常</text>
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<view class="info-row">
|
||||
<view class="info-item">
|
||||
<text class="info-label">当前产量:</text>
|
||||
<text class="info-value">2580 件</text>
|
||||
</view>
|
||||
<view class="info-item">
|
||||
<text class="info-label">合格率:</text>
|
||||
<text class="info-value">98.5%</text>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<view style="display: flex; justify-content: space-between; align-items: center; padding: 20rpx; background-color: #d9edf6; border-radius: 10rpx;">
|
||||
<text>酸洗</text>
|
||||
<text>6390000</text>
|
||||
</view>
|
||||
|
||||
<view style="border-radius: 10rpx; overflow: hidden;">
|
||||
<view style="display: flex; justify-content: space-between; align-items: center; padding: 20rpx; background-color: #d9edf6; border: 1px solid #d9edf6;">
|
||||
<text>入口活套</text>
|
||||
<text>6390000</text>
|
||||
</view>
|
||||
<view class="info-container">
|
||||
<view class="info-row">
|
||||
<view class="info-item">
|
||||
<text class="info-label">设备编号:</text>
|
||||
<text class="info-value">M-001</text>
|
||||
</view>
|
||||
<view class="info-item">
|
||||
<text class="info-label">运行状态:</text>
|
||||
<text class="info-value">正常</text>
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<view class="info-row">
|
||||
<view class="info-item">
|
||||
<text class="info-label">当前产量:</text>
|
||||
<text class="info-value">2580 件</text>
|
||||
</view>
|
||||
<view class="info-item">
|
||||
<text class="info-label">合格率:</text>
|
||||
<text class="info-value">98.5%</text>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
</klp-collapse-panel>
|
||||
</view>
|
||||
|
||||
<view class="content-card">
|
||||
<klp-collapse-panel title="能耗">
|
||||
<view class="metric-container">
|
||||
<!-- 工艺线速度指标 -->
|
||||
<view class="metric-item">
|
||||
<view class="metric-value">
|
||||
9.9
|
||||
</view>
|
||||
<view class="metric-label">
|
||||
工艺缎带钢线速度
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<!-- 出口线速度指标 -->
|
||||
<view class="metric-item">
|
||||
<view class="metric-value team-number">
|
||||
126.0
|
||||
</view>
|
||||
<view class="metric-label">
|
||||
轧机出口带钢线速度
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
</klp-collapse-panel>
|
||||
</view>
|
||||
</scroll-view>
|
||||
|
||||
<scroll-view scroll-y v-if="currentTab == 2">
|
||||
<klp-product-statistic></klp-product-statistic>
|
||||
</scroll-view>
|
||||
|
||||
<scroll-view scroll-y v-if="currentTab == 3">
|
||||
<klp-shutdown-statistic></klp-shutdown-statistic>
|
||||
</scroll-view>
|
||||
|
||||
<scroll-view scroll-y v-if="currentTab == 4">
|
||||
<klp-team-performance></klp-team-performance>
|
||||
</scroll-view>
|
||||
</view>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
export default {
|
||||
// 3. 响应式数据(替代 Vue 3 的 ref)
|
||||
data() {
|
||||
return {
|
||||
currentTab: 1, // 当前激活的标签页(默认实时监控)
|
||||
tabData: [ // 标签页配置
|
||||
{ text: "实时监控", value: 1 },
|
||||
{ text: "生产统计", value: 2 },
|
||||
{ text: "停机统计", value: 3 },
|
||||
{ text: "班组绩效", value: 4 }
|
||||
],
|
||||
chartData: {} // 图表数据(初始化空对象,后续加载)
|
||||
};
|
||||
},
|
||||
// 4. 生命周期钩子(替代 Vue 3 的 onMounted)
|
||||
mounted() {
|
||||
this.getServerData(); // 页面挂载后加载图表数据
|
||||
},
|
||||
// 5. 方法定义(所有数据处理与逻辑)
|
||||
methods: {
|
||||
// 模拟从服务器获取图表数据
|
||||
getServerData() {
|
||||
setTimeout(() => {
|
||||
// 模拟服务器返回的图表数据
|
||||
const serverRes = {
|
||||
categories: ["2016", "2017", "2018", "2019", "2020", "2021"],
|
||||
series: [
|
||||
{ name: "目标值", data: [35, 36, 31, 33, 13, 34] },
|
||||
{ name: "完成量", data: [18, 27, 21, 24, 6, 28] }
|
||||
]
|
||||
};
|
||||
// 深拷贝避免 Vue 2 响应式引用问题
|
||||
this.chartData = JSON.parse(JSON.stringify(serverRes));
|
||||
}, 500);
|
||||
}
|
||||
}
|
||||
};
|
||||
</script>
|
||||
|
||||
<style scoped lang="scss">
|
||||
page {
|
||||
background-color: #b2b2b2;
|
||||
height: 100vh;
|
||||
overflow: auto;
|
||||
}
|
||||
|
||||
/* 滚动视图间隙(原代码选择器可能笔误,保留原逻辑) */
|
||||
view-scroll {
|
||||
gap: 30rpx;
|
||||
}
|
||||
|
||||
/* 标签页容器样式 */
|
||||
.tab {
|
||||
margin: auto;
|
||||
display: flex;
|
||||
box-sizing: border-box;
|
||||
justify-content: center;
|
||||
top: 88rpx; /* 需配合 position: sticky 生效,原代码未加,可根据需求补充 */
|
||||
position: sticky; /* 补充粘性定位,确保标签页滚动时固定在顶部 */
|
||||
z-index: 999;
|
||||
background-color: #fff;
|
||||
padding: 10rpx 0; /* 补充内边距,优化点击体验 */
|
||||
}
|
||||
|
||||
/* 内容卡片样式 */
|
||||
.content-card {
|
||||
border-radius: 16rpx; /* 补充圆角,与设计风格统一 */
|
||||
overflow: hidden; /* 防止内部内容溢出卡片 */
|
||||
}
|
||||
|
||||
/* 指标容器样式 */
|
||||
.metric-container {
|
||||
display: flex;
|
||||
justify-content: space-around;
|
||||
background-color: white;
|
||||
padding: 20rpx 0;
|
||||
}
|
||||
|
||||
/* 单个指标项样式 */
|
||||
.metric-item {
|
||||
flex: 1;
|
||||
text-align: center;
|
||||
padding: 32rpx;
|
||||
border-radius: 12rpx;
|
||||
transition: all 0.3s;
|
||||
margin: 0 10rpx; /* 补充左右间距,避免指标过挤 */
|
||||
background-color: #f8f9fa; /* 补充背景色,区分指标区域 */
|
||||
}
|
||||
|
||||
/* 指标数值样式 */
|
||||
.metric-value {
|
||||
font-size: 48rpx;
|
||||
font-weight: 600;
|
||||
margin-bottom: 16rpx;
|
||||
line-height: 1.2;
|
||||
color: #333;
|
||||
}
|
||||
|
||||
/* 指标标签样式 */
|
||||
.metric-label {
|
||||
font-size: 28rpx;
|
||||
color: #666;
|
||||
letter-spacing: 2rpx;
|
||||
}
|
||||
|
||||
/* 机组跟踪信息容器 */
|
||||
.info-container {
|
||||
padding: 20rpx;
|
||||
background: #fff;
|
||||
border-radius: 12rpx;
|
||||
border-top: 1px solid #eee; /* 补充上边框,区分标题与内容 */
|
||||
}
|
||||
|
||||
/* 信息行样式 */
|
||||
.info-row {
|
||||
display: flex;
|
||||
justify-content: space-between;
|
||||
margin-bottom: 24rpx;
|
||||
|
||||
&:last-child {
|
||||
margin-bottom: 0;
|
||||
}
|
||||
}
|
||||
|
||||
/* 单个信息项样式 */
|
||||
.info-item {
|
||||
flex: 0 0 48%; /* 留出4%的间隔,避免内容溢出 */
|
||||
display: flex;
|
||||
align-items: baseline; /* 文字基线对齐,排版更整齐 */
|
||||
}
|
||||
|
||||
/* 信息标签样式 */
|
||||
.info-label {
|
||||
color: #666;
|
||||
font-size: 28rpx;
|
||||
flex-shrink: 0;
|
||||
margin-right: 16rpx;
|
||||
}
|
||||
|
||||
/* 信息数值样式 */
|
||||
.info-value {
|
||||
color: #333;
|
||||
font-size: 30rpx;
|
||||
font-weight: 500;
|
||||
word-break: break-all; /* 长文本自动换行,防止超出容器 */
|
||||
}
|
||||
</style>
|
||||
313
apps/hand-factory/components/lines/zinc3.vue
Normal file
313
apps/hand-factory/components/lines/zinc3.vue
Normal file
@@ -0,0 +1,313 @@
|
||||
<template>
|
||||
<view>
|
||||
<view class="tab">
|
||||
<uni-data-checkbox
|
||||
mode="tag"
|
||||
selectedColor="#2bf"
|
||||
v-model="currentTab"
|
||||
:localdata="tabData"
|
||||
></uni-data-checkbox>
|
||||
</view>
|
||||
|
||||
<scroll-view scroll-y v-if="currentTab === 1">
|
||||
<view class="content-card">
|
||||
<view class="metric-container">
|
||||
<!-- 网络状态指标 -->
|
||||
<view class="metric-item">
|
||||
<view class="metric-value">
|
||||
正常
|
||||
</view>
|
||||
<view class="metric-label">
|
||||
网络状态
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<!-- 班组指标 -->
|
||||
<view class="metric-item">
|
||||
<view class="metric-value team-number">
|
||||
乙 / 中
|
||||
</view>
|
||||
<view class="metric-label">
|
||||
当前班组
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<view class="content-card">
|
||||
<klp-collapse-panel title="状态统计">
|
||||
<qiun-data-charts type="line" :chartData="chartData" />
|
||||
</klp-collapse-panel>
|
||||
</view>
|
||||
|
||||
<view class="content-card">
|
||||
<klp-collapse-panel title="轧机状态">
|
||||
<qiun-data-charts type="column" :chartData="chartData" />
|
||||
</klp-collapse-panel>
|
||||
</view>
|
||||
|
||||
<view class="content-card">
|
||||
<klp-collapse-panel title="机组跟踪">
|
||||
<view style="padding: 30rpx; display: flex; flex-direction: column; align-items: stretch; justify-content: center; gap: 20rpx;">
|
||||
<view style="display: flex; justify-content: space-between; align-items: center; padding: 20rpx; background-color: #d9edf6; border-radius: 10rpx;">
|
||||
<text>轧机</text>
|
||||
<text>6390000</text>
|
||||
</view>
|
||||
|
||||
<view style="border-radius: 10rpx; overflow: hidden;">
|
||||
<view style="display: flex; justify-content: space-between; align-items: center; padding: 20rpx; background-color: #d9edf6; border: 1px solid #d9edf6;">
|
||||
<text>圆剪盘</text>
|
||||
<text>6390000</text>
|
||||
</view>
|
||||
<view class="info-container">
|
||||
<view class="info-row">
|
||||
<view class="info-item">
|
||||
<text class="info-label">设备编号:</text>
|
||||
<text class="info-value">M-001</text>
|
||||
</view>
|
||||
<view class="info-item">
|
||||
<text class="info-label">运行状态:</text>
|
||||
<text class="info-value">正常</text>
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<view class="info-row">
|
||||
<view class="info-item">
|
||||
<text class="info-label">当前产量:</text>
|
||||
<text class="info-value">2580 件</text>
|
||||
</view>
|
||||
<view class="info-item">
|
||||
<text class="info-label">合格率:</text>
|
||||
<text class="info-value">98.5%</text>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<view style="display: flex; justify-content: space-between; align-items: center; padding: 20rpx; background-color: #d9edf6; border-radius: 10rpx;">
|
||||
<text>酸洗</text>
|
||||
<text>6390000</text>
|
||||
</view>
|
||||
|
||||
<view style="border-radius: 10rpx; overflow: hidden;">
|
||||
<view style="display: flex; justify-content: space-between; align-items: center; padding: 20rpx; background-color: #d9edf6; border: 1px solid #d9edf6;">
|
||||
<text>入口活套</text>
|
||||
<text>6390000</text>
|
||||
</view>
|
||||
<view class="info-container">
|
||||
<view class="info-row">
|
||||
<view class="info-item">
|
||||
<text class="info-label">设备编号:</text>
|
||||
<text class="info-value">M-001</text>
|
||||
</view>
|
||||
<view class="info-item">
|
||||
<text class="info-label">运行状态:</text>
|
||||
<text class="info-value">正常</text>
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<view class="info-row">
|
||||
<view class="info-item">
|
||||
<text class="info-label">当前产量:</text>
|
||||
<text class="info-value">2580 件</text>
|
||||
</view>
|
||||
<view class="info-item">
|
||||
<text class="info-label">合格率:</text>
|
||||
<text class="info-value">98.5%</text>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
</klp-collapse-panel>
|
||||
</view>
|
||||
|
||||
<view class="content-card">
|
||||
<klp-collapse-panel title="能耗">
|
||||
<view class="metric-container">
|
||||
<!-- 工艺线速度指标 -->
|
||||
<view class="metric-item">
|
||||
<view class="metric-value">
|
||||
9.9
|
||||
</view>
|
||||
<view class="metric-label">
|
||||
工艺缎带钢线速度
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<!-- 出口线速度指标 -->
|
||||
<view class="metric-item">
|
||||
<view class="metric-value team-number">
|
||||
126.0
|
||||
</view>
|
||||
<view class="metric-label">
|
||||
轧机出口带钢线速度
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
</klp-collapse-panel>
|
||||
</view>
|
||||
</scroll-view>
|
||||
|
||||
<scroll-view scroll-y v-if="currentTab == 2">
|
||||
<klp-product-statistic></klp-product-statistic>
|
||||
</scroll-view>
|
||||
|
||||
<scroll-view scroll-y v-if="currentTab == 3">
|
||||
<klp-shutdown-statistic></klp-shutdown-statistic>
|
||||
</scroll-view>
|
||||
|
||||
<scroll-view scroll-y v-if="currentTab == 4">
|
||||
<klp-team-performance></klp-team-performance>
|
||||
</scroll-view>
|
||||
</view>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
export default {
|
||||
// 3. 响应式数据(替代 Vue 3 的 ref)
|
||||
data() {
|
||||
return {
|
||||
currentTab: 1, // 当前激活的标签页(默认实时监控)
|
||||
tabData: [ // 标签页配置
|
||||
{ text: "实时监控", value: 1 },
|
||||
{ text: "生产统计", value: 2 },
|
||||
{ text: "停机统计", value: 3 },
|
||||
{ text: "班组绩效", value: 4 }
|
||||
],
|
||||
chartData: {} // 图表数据(初始化空对象,后续加载)
|
||||
};
|
||||
},
|
||||
// 4. 生命周期钩子(替代 Vue 3 的 onMounted)
|
||||
mounted() {
|
||||
this.getServerData(); // 页面挂载后加载图表数据
|
||||
},
|
||||
// 5. 方法定义(所有数据处理与逻辑)
|
||||
methods: {
|
||||
// 模拟从服务器获取图表数据
|
||||
getServerData() {
|
||||
setTimeout(() => {
|
||||
// 模拟服务器返回的图表数据
|
||||
const serverRes = {
|
||||
categories: ["2016", "2017", "2018", "2019", "2020", "2021"],
|
||||
series: [
|
||||
{ name: "目标值", data: [35, 36, 31, 33, 13, 34] },
|
||||
{ name: "完成量", data: [18, 27, 21, 24, 6, 28] }
|
||||
]
|
||||
};
|
||||
// 深拷贝避免 Vue 2 响应式引用问题
|
||||
this.chartData = JSON.parse(JSON.stringify(serverRes));
|
||||
}, 500);
|
||||
}
|
||||
}
|
||||
};
|
||||
</script>
|
||||
|
||||
<style scoped lang="scss">
|
||||
page {
|
||||
background-color: #b2b2b2;
|
||||
height: 100vh;
|
||||
overflow: auto;
|
||||
}
|
||||
|
||||
/* 滚动视图间隙(原代码选择器可能笔误,保留原逻辑) */
|
||||
view-scroll {
|
||||
gap: 30rpx;
|
||||
}
|
||||
|
||||
/* 标签页容器样式 */
|
||||
.tab {
|
||||
margin: auto;
|
||||
display: flex;
|
||||
box-sizing: border-box;
|
||||
justify-content: center;
|
||||
top: 88rpx; /* 需配合 position: sticky 生效,原代码未加,可根据需求补充 */
|
||||
position: sticky; /* 补充粘性定位,确保标签页滚动时固定在顶部 */
|
||||
z-index: 999;
|
||||
background-color: #fff;
|
||||
padding: 10rpx 0; /* 补充内边距,优化点击体验 */
|
||||
}
|
||||
|
||||
/* 内容卡片样式 */
|
||||
.content-card {
|
||||
border-radius: 16rpx; /* 补充圆角,与设计风格统一 */
|
||||
overflow: hidden; /* 防止内部内容溢出卡片 */
|
||||
}
|
||||
|
||||
/* 指标容器样式 */
|
||||
.metric-container {
|
||||
display: flex;
|
||||
justify-content: space-around;
|
||||
background-color: white;
|
||||
padding: 20rpx 0;
|
||||
}
|
||||
|
||||
/* 单个指标项样式 */
|
||||
.metric-item {
|
||||
flex: 1;
|
||||
text-align: center;
|
||||
padding: 32rpx;
|
||||
border-radius: 12rpx;
|
||||
transition: all 0.3s;
|
||||
margin: 0 10rpx; /* 补充左右间距,避免指标过挤 */
|
||||
background-color: #f8f9fa; /* 补充背景色,区分指标区域 */
|
||||
}
|
||||
|
||||
/* 指标数值样式 */
|
||||
.metric-value {
|
||||
font-size: 48rpx;
|
||||
font-weight: 600;
|
||||
margin-bottom: 16rpx;
|
||||
line-height: 1.2;
|
||||
color: #333;
|
||||
}
|
||||
|
||||
/* 指标标签样式 */
|
||||
.metric-label {
|
||||
font-size: 28rpx;
|
||||
color: #666;
|
||||
letter-spacing: 2rpx;
|
||||
}
|
||||
|
||||
/* 机组跟踪信息容器 */
|
||||
.info-container {
|
||||
padding: 20rpx;
|
||||
background: #fff;
|
||||
border-radius: 12rpx;
|
||||
border-top: 1px solid #eee; /* 补充上边框,区分标题与内容 */
|
||||
}
|
||||
|
||||
/* 信息行样式 */
|
||||
.info-row {
|
||||
display: flex;
|
||||
justify-content: space-between;
|
||||
margin-bottom: 24rpx;
|
||||
|
||||
&:last-child {
|
||||
margin-bottom: 0;
|
||||
}
|
||||
}
|
||||
|
||||
/* 单个信息项样式 */
|
||||
.info-item {
|
||||
flex: 0 0 48%; /* 留出4%的间隔,避免内容溢出 */
|
||||
display: flex;
|
||||
align-items: baseline; /* 文字基线对齐,排版更整齐 */
|
||||
}
|
||||
|
||||
/* 信息标签样式 */
|
||||
.info-label {
|
||||
color: #666;
|
||||
font-size: 28rpx;
|
||||
flex-shrink: 0;
|
||||
margin-right: 16rpx;
|
||||
}
|
||||
|
||||
/* 信息数值样式 */
|
||||
.info-value {
|
||||
color: #333;
|
||||
font-size: 30rpx;
|
||||
font-weight: 500;
|
||||
word-break: break-all; /* 长文本自动换行,防止超出容器 */
|
||||
}
|
||||
</style>
|
||||
320
apps/hand-factory/components/qiun-data-charts/changelog.md
Normal file
320
apps/hand-factory/components/qiun-data-charts/changelog.md
Normal file
@@ -0,0 +1,320 @@
|
||||
## 2.5.0-20230101(2023-01-01)
|
||||
- 秋云图表组件 修改条件编译顺序,确保uniapp的cli方式的项目依赖不完整时可以正常显示
|
||||
- 秋云图表组件 恢复props属性directory的使用,以修复vue3项目中,开启echarts后,echarts目录识别错误的bug
|
||||
- uCharts.js 修复区域图、混合图只有一个数据时图表显示不正确的bug
|
||||
- uCharts.js 修复折线图、区域图中时间轴类别图表tooltip指示点显示不正确的bug
|
||||
- uCharts.js 修复x轴使用labelCount时,并且boundaryGap = 'justify' 并且关闭Y轴显示的时候,最后一个坐标值不显示的bug
|
||||
- uCharts.js 修复折线图只有一组数据时 ios16 渲染颜色不正确的bug
|
||||
- uCharts.js 修复玫瑰图半径显示不正确的bug
|
||||
- uCharts.js 柱状图、山峰图增加正负图功能,y轴网格如果需要显示0轴则由 min max 及 splitNumber 确定,后续版本优化自动显示0轴
|
||||
- uCharts.js 柱状图column增加 opts.extra.column.labelPosition,数据标签位置,有效值为 outside外部, insideTop内顶部, center内中间, bottom内底部
|
||||
- uCharts.js 雷达图radar增加 opts.extra.radar.labelShow,否显示各项标识文案是,默认true
|
||||
- uCharts.js 提示窗tooltip增加 opts.extra.tooltip.boxPadding,提示窗边框填充距离,默认3px
|
||||
- uCharts.js 提示窗tooltip增加 opts.extra.tooltip.fontSize,提示窗字体大小配置,默认13px
|
||||
- uCharts.js 提示窗tooltip增加 opts.extra.tooltip.lineHeight,提示窗文字行高,默认20px
|
||||
- uCharts.js 提示窗tooltip增加 opts.extra.tooltip.legendShow,是否显示左侧图例,默认true
|
||||
- uCharts.js 提示窗tooltip增加 opts.extra.tooltip.legendShape,图例形状,图例标识样式,有效值为 auto自动跟随图例, diamond◆, circle●, triangle▲, square■, rect▬, line-
|
||||
- uCharts.js 标记线markLine增加 opts.extra.markLine.labelFontSize,字体大小配置,默认13px
|
||||
- uCharts.js 标记线markLine增加 opts.extra.markLine.labelPadding,标签边框内填充距离,默认6px
|
||||
- uCharts.js 折线图line增加 opts.extra.line.linearType,渐变色类型,可选值 none关闭渐变色,custom 自定义渐变色。使用自定义渐变色时请赋值serie.linearColor作为颜色值
|
||||
- uCharts.js 折线图line增加 serie.linearColor,渐变色数组,格式为2维数组[起始位置,颜色值],例如[[0,'#0EE2F8'],[0.3,'#2BDCA8'],[0.6,'#1890FF'],[1,'#9A60B4']]
|
||||
- uCharts.js 折线图line增加 opts.extra.line.onShadow,是否开启折线阴影,开启后请赋值serie.setShadow阴影设置
|
||||
- uCharts.js 折线图line增加 serie.setShadow,阴影配置,格式为4位数组:[offsetX,offsetY,blur,color]
|
||||
- uCharts.js 折线图line增加 opts.extra.line.animation,动画效果方向,可选值为vertical 垂直动画效果,horizontal 水平动画效果
|
||||
- uCharts.js X轴xAxis增加 opts.xAxis.lineHeight,X轴字体行高,默认20px
|
||||
- uCharts.js X轴xAxis增加 opts.xAxis.marginTop,X轴文字距离轴线的距离,默认0px
|
||||
- uCharts.js X轴xAxis增加 opts.xAxis.title,当前X轴标题
|
||||
- uCharts.js X轴xAxis增加 opts.xAxis.titleFontSize,标题字体大小,默认13px
|
||||
- uCharts.js X轴xAxis增加 opts.xAxis.titleOffsetY,标题纵向偏移距离,负数为向上偏移,正数向下偏移
|
||||
- uCharts.js X轴xAxis增加 opts.xAxis.titleOffsetX,标题横向偏移距离,负数为向左偏移,正数向右偏移
|
||||
- uCharts.js X轴xAxis增加 opts.xAxis.titleFontColor,标题字体颜色,默认#666666
|
||||
|
||||
## 报错TypeError: Cannot read properties of undefined (reading 'length')
|
||||
- 如果是uni-modules版本组件,请先登录HBuilderX账号;
|
||||
- 在HBuilderX中的manifest.json,点击重新获取uniapp的appid,或者删除appid重新粘贴,重新运行;
|
||||
- 如果是cli项目请使用码云上的非uniCloud版本组件;
|
||||
- 或者添加uniCloud的依赖;
|
||||
- 或者使用原生uCharts;
|
||||
## 2.4.5-20221130(2022-11-30)
|
||||
- uCharts.js 优化tooltip当文字很多变为左侧显示时,如果画布仍显显示不下,提示框错位置变为以左侧0位置起画
|
||||
- uCharts.js 折线图修复特殊情况下只有单点数据,并改变线宽后点变为圆形的bug
|
||||
- uCharts.js 修复Y轴disabled启用后无效并报错的bug
|
||||
- uCharts.js 修复仪表盘起始结束角度特殊情况下显示不正确的bug
|
||||
- uCharts.js 雷达图新增参数 opts.extra.radar.radius , 自定义雷达图半径
|
||||
- uCharts.js 折线图、区域图增加tooltip指示点,opts.extra.line.activeType/opts.extra.area.activeType,可选值"none"不启用激活指示点,"hollow"空心点模式,"solid"实心点模式
|
||||
## 2.4.4-20221102(2022-11-02)
|
||||
- 秋云图表组件 修复使用echarts时reload、reshow无法调用重新渲染的bug,[详见码云PR](https://gitee.com/uCharts/uCharts/pulls/40)
|
||||
- 秋云图表组件 修复使用echarts时,初始化时宽高不正确的bug,[详见码云PR](https://gitee.com/uCharts/uCharts/pulls/42)
|
||||
- 秋云图表组件 修复uniapp的h5使用history模式时,无法加载echarts的bug
|
||||
- 秋云图表组件 小程序端@complete、@scrollLeft、@scrollRight、@getTouchStart、@getTouchMove、@getTouchEnd事件增加opts参数传出,方便一些特殊需求的交互获取数据。
|
||||
|
||||
- uCharts.js 修复calTooltipYAxisData方法内formatter格式化方法未与y轴方法同步的问题,[详见码云PR](https://gitee.com/uCharts/uCharts/pulls/43)
|
||||
- uCharts.js 地图新增参数opts.series[i].fillOpacity,以透明度方式来设置颜色过度效果,[详见码云PR](https://gitee.com/uCharts/uCharts/pulls/38)
|
||||
- uCharts.js 地图新增参数opts.extra.map.active,是否启用点击激活变色
|
||||
- uCharts.js 地图新增参数opts.extra.map.activeTextColor,是否启用点击激活变色
|
||||
- uCharts.js 地图新增渲染完成事件renderComplete
|
||||
- uCharts.js 漏斗图修复当部分数据相同时tooltip提示窗点击错误的bug
|
||||
- uCharts.js 漏斗图新增参数series.data[i].centerText 居中标签文案
|
||||
- uCharts.js 漏斗图新增参数series.data[i].centerTextSize 居中标签文案字体大小,默认opts.fontSize
|
||||
- uCharts.js 漏斗图新增参数series.data[i].centerTextColor 居中标签文案字体颜色,默认#FFFFFF
|
||||
- uCharts.js 漏斗图新增参数opts.extra.funnel.minSize 最小值的最小宽度,默认0
|
||||
- uCharts.js 进度条新增参数opts.extra.arcbar.direction,动画方向,可选值为cw顺时针、ccw逆时针
|
||||
- uCharts.js 混合图新增参数opts.extra.mix.line.width,折线的宽度,默认2
|
||||
- uCharts.js 修复tooltip开启horizentalLine水平横线标注时,图表显示错位的bug
|
||||
- uCharts.js 优化tooltip当文字很多变为左侧显示时,如果画布仍显显示不下,提示框错位置变为以左侧0位置起画
|
||||
- uCharts.js 修复开启滚动条后X轴文字超出绘图区域后的隐藏逻辑
|
||||
- uCharts.js 柱状图、条状图修复堆叠模式不能通过{value,color}赋值单个柱子颜色的问题
|
||||
- uCharts.js 气泡图修复不识别series.textSize和series.textColor的bug
|
||||
|
||||
## 报错TypeError: Cannot read properties of undefined (reading 'length')
|
||||
1. 如果是uni-modules版本组件,请先登录HBuilderX账号;
|
||||
2. 在HBuilderX中的manifest.json,点击重新获取uniapp的appid,或者删除appid重新粘贴,重新运行;
|
||||
3. 如果是cli项目请使用码云上的非uniCloud版本组件;
|
||||
4. 或者添加uniCloud的依赖;
|
||||
5. 或者使用原生uCharts;
|
||||
## 2.4.3-20220505(2022-05-05)
|
||||
- 秋云图表组件 修复开启canvas2d后将series赋值为空数组显示加载图标时,再次赋值后画布闪动的bug
|
||||
- 秋云图表组件 修复升级hbx最新版后ECharts的highlight方法报错的bug
|
||||
- uCharts.js 雷达图新增参数opts.extra.radar.gridEval,数据点位网格抽希,默认1
|
||||
- uCharts.js 雷达图新增参数opts.extra.radar.axisLabel, 是否显示刻度点值,默认false
|
||||
- uCharts.js 雷达图新增参数opts.extra.radar.axisLabelTofix,刻度点值小数位数,默认0
|
||||
- uCharts.js 雷达图新增参数opts.extra.radar.labelPointShow,是否显示末端刻度圆点,默认false
|
||||
- uCharts.js 雷达图新增参数opts.extra.radar.labelPointRadius,刻度圆点的半径,默认3
|
||||
- uCharts.js 雷达图新增参数opts.extra.radar.labelPointColor,刻度圆点的颜色,默认#cccccc
|
||||
- uCharts.js 雷达图新增参数opts.extra.radar.linearType,渐变色类型,可选值"none"关闭渐变,"custom"开启渐变
|
||||
- uCharts.js 雷达图新增参数opts.extra.radar.customColor,自定义渐变颜色,数组类型对应series的数组长度以匹配不同series颜色的不同配色方案,例如["#FA7D8D", "#EB88E2"]
|
||||
- uCharts.js 雷达图优化支持series.textColor、series.textSize属性
|
||||
- uCharts.js 柱状图中温度计式图标,优化支持全圆角类型,修复边框有缝隙的bug,详见官网【演示】中的温度计图表
|
||||
- uCharts.js 柱状图新增参数opts.extra.column.activeWidth,当前点击柱状图的背景宽度,默认一个单元格单位
|
||||
- uCharts.js 混合图增加opts.extra.mix.area.gradient 区域图是否开启渐变色
|
||||
- uCharts.js 混合图增加opts.extra.mix.area.opacity 区域图透明度,默认0.2
|
||||
- uCharts.js 饼图、圆环图、玫瑰图、漏斗图,增加opts.series[0].data[i].labelText,自定义标签文字,避免formatter格式化的繁琐,详见官网【演示】中的饼图
|
||||
- uCharts.js 饼图、圆环图、玫瑰图、漏斗图,增加opts.series[0].data[i].labelShow,自定义是否显示某一个指示标签,避免因饼图类别太多导致标签重复或者居多导致图形变形的问题,详见官网【演示】中的饼图
|
||||
- uCharts.js 增加opts.series[i].legendText/opts.series[0].data[i].legendText(与series.name同级)自定义图例显示文字的方法
|
||||
- uCharts.js 优化X轴、Y轴formatter格式化方法增加形参,统一为fromatter:function(value,index,opts){}
|
||||
- uCharts.js 修复横屏模式下无法使用双指缩放方法的bug
|
||||
- uCharts.js 修复当只有一条数据或者多条数据值相等的时候Y轴自动计算的最大值错误的bug
|
||||
- 【官网模板】增加外部自定义图例与图表交互的例子,[点击跳转](https://www.ucharts.cn/v2/#/layout/info?id=2)
|
||||
|
||||
## 注意:非unimodules 版本如因更新 hbx 至 3.4.7 导致报错如下,请到码云更新非 unimodules 版本组件,[点击跳转](https://gitee.com/uCharts/uCharts/tree/master/uni-app/uCharts-%E7%BB%84%E4%BB%B6)
|
||||
> Error in callback for immediate watcher "uchartsOpts": "SyntaxError: Unexpected token u in JSON at position 0"
|
||||
## 2.4.2-20220421(2022-04-21)
|
||||
- 秋云图表组件 修复HBX升级3.4.6.20220420版本后echarts报错的问题
|
||||
## 2.4.2-20220420(2022-04-20)
|
||||
## 重要!此版本uCharts新增了很多功能,修复了诸多已知问题
|
||||
- 秋云图表组件 新增onzoom开启双指缩放功能(仅uCharts),前提需要直角坐标系类图表类型,并且ontouch为true、opts.enableScroll为true,详见实例项目K线图
|
||||
- 秋云图表组件 新增optsWatch是否监听opts变化,关闭optsWatch后,动态修改opts不会触发图表重绘
|
||||
- 秋云图表组件 修复开启canvas2d功能后,动态更新数据后画布闪动的bug
|
||||
- 秋云图表组件 去除directory属性,改为自动获取echarts.min.js路径(升级不受影响)
|
||||
- 秋云图表组件 增加getImage()方法及@getImage事件,通过ref调用getImage()方法获,触发@getImage事件获取当前画布的base64图片文件流。
|
||||
- 秋云图表组件 支付宝、字节跳动、飞书、快手小程序支持开启canvas2d同层渲染设置。
|
||||
- 秋云图表组件 新增加【非uniCloud】版本组件,避免有些不需要uniCloud的使用组件发布至小程序需要提交隐私声明问题,请到码云[【非uniCloud版本】](https://gitee.com/uCharts/uCharts/tree/master/uni-app/uCharts-%E7%BB%84%E4%BB%B6),或npm[【非uniCloud版本】](https://www.npmjs.com/package/@qiun/uni-ucharts)下载使用。
|
||||
- uCharts.js 新增dobuleZoom双指缩放功能
|
||||
- uCharts.js 新增山峰图type="mount",数据格式为饼图类格式,不需要传入categories,具体详见新版官网在线演示
|
||||
- uCharts.js 修复折线图当数据中存在null时tooltip报错的bug
|
||||
- uCharts.js 修复饼图类当画布比较小时自动计算的半径是负数报错的bug
|
||||
- uCharts.js 统一各图表类型的series.formatter格式化方法的形参为(val, index, series, opts),方便格式化时有更多参数可用
|
||||
- uCharts.js 标记线功能增加labelText自定义显示文字,增加labelAlign标签显示位置(左侧或右侧),增加标签显示位置微调labelOffsetX、labelOffsetY
|
||||
- uCharts.js 修复条状图当数值很小时开启圆角后样式错误的bug
|
||||
- uCharts.js 修复X轴开启disabled后,X轴仍占用空间的bug
|
||||
- uCharts.js 修复X轴开启滚动条并且开启rotateLabel后,X轴文字与滚动条重叠的bug
|
||||
- uCharts.js 增加X轴rotateAngle文字旋转自定义角度,取值范围(-90至90)
|
||||
- uCharts.js 修复地图文字标签层级显示不正确的bug
|
||||
- uCharts.js 修复饼图、圆环图、玫瑰图当数据全部为0的时候不显示数据标签的bug
|
||||
- uCharts.js 修复当opts.padding上边距为0时,Y轴顶部刻度标签位置不正确的bug
|
||||
|
||||
## 另外我们还开发了各大原生小程序组件,已发布至码云和npm
|
||||
[https://gitee.com/uCharts/uCharts](https://gitee.com/uCharts/uCharts)
|
||||
[https://www.npmjs.com/~qiun](https://www.npmjs.com/~qiun)
|
||||
|
||||
## 对于原生uCharts文档我们已上线新版官方网站,详情点击下面链接进入官网
|
||||
[https://www.uCharts.cn/v2/](https://www.ucharts.cn/v2/)
|
||||
## 2.3.7-20220122(2022-01-22)
|
||||
## 重要!使用vue3编译,请使用cli模式并升级至最新依赖,HbuilderX编译需要使用3.3.8以上版本
|
||||
- uCharts.js 修复uni-app平台组件模式使用vue3编译到小程序报错的bug。
|
||||
## 2.3.7-20220118(2022-01-18)
|
||||
## 注意,使用vue3的前提是需要3.3.8.20220114-alpha版本的HBuilder!
|
||||
## 2.3.67-20220118(2022-01-18)
|
||||
- 秋云图表组件 组件初步支持vue3,全端编译会有些问题,具体详见下面修改:
|
||||
1. 小程序端运行时,在uni_modules文件夹的qiun-data-charts.js中搜索 new uni_modules_qiunDataCharts_js_sdk_uCharts_uCharts.uCharts,将.uCharts去掉。
|
||||
2. 小程序端发行时,在uni_modules文件夹的qiun-data-charts.js中搜索 new e.uCharts,将.uCharts去掉,变为 new e。
|
||||
3. 如果觉得上述步骤比较麻烦,如果您的项目只编译到小程序端,可以修改u-charts.js最后一行导出方式,将 export default uCharts;变更为 export default { uCharts: uCharts }; 这样变更后,H5和App端的renderjs会有问题,请开发者自行选择。(此问题非组件问题,请等待DC官方修复Vue3的小程序端)
|
||||
## 2.3.6-20220111(2022-01-11)
|
||||
- 秋云图表组件 修改组件 props 属性中的 background 默认值为 rgba(0,0,0,0)
|
||||
## 2.3.6-20211201(2021-12-01)
|
||||
- uCharts.js 修复bar条状图开启圆角模式时,值很小时圆角渲染错误的bug
|
||||
## 2.3.5-20211014(2021-10-15)
|
||||
- uCharts.js 增加vue3的编译支持(仅原生uCharts,qiun-data-charts组件后续会支持,请关注更新)
|
||||
## 2.3.4-20211012(2021-10-12)
|
||||
- 秋云图表组件 修复 mac os x 系统 mouseover 事件丢失的 bug
|
||||
## 2.3.3-20210706(2021-07-06)
|
||||
- uCharts.js 增加雷达图开启数据点值(opts.dataLabel)的显示
|
||||
## 2.3.2-20210627(2021-06-27)
|
||||
- 秋云图表组件 修复tooltipCustom个别情况下传值不正确报错TypeError: Cannot read property 'name' of undefined的bug
|
||||
## 2.3.1-20210616(2021-06-16)
|
||||
- uCharts.js 修复圆角柱状图使用4角圆角时,当数值过大时不正确的bug
|
||||
## 2.3.0-20210612(2021-06-12)
|
||||
- uCharts.js 【重要】uCharts增加nvue兼容,可在nvue项目中使用gcanvas组件渲染uCharts,[详见码云uCharts-demo-nvue](https://gitee.com/uCharts/uCharts)
|
||||
- 秋云图表组件 增加tapLegend属性,是否开启图例点击交互事件
|
||||
- 秋云图表组件 getIndex事件中增加返回uCharts实例中的opts参数,以便在页面中调用参数
|
||||
- 示例项目 pages/other/other.vue增加app端自定义tooltip的方法,详见showOptsTooltip方法
|
||||
## 2.2.1-20210603(2021-06-03)
|
||||
- uCharts.js 修复饼图、圆环图、玫瑰图,当起始角度不为0时,tooltip位置不准确的bug
|
||||
- uCharts.js 增加温度计式柱状图开启顶部半圆形的配置
|
||||
## 2.2.0-20210529(2021-05-29)
|
||||
- uCharts.js 增加条状图type="bar"
|
||||
- 示例项目 pages/ucharts/ucharts.vue增加条状图的demo
|
||||
## 2.1.7-20210524(2021-05-24)
|
||||
- uCharts.js 修复大数据量模式下曲线图不平滑的bug
|
||||
## 2.1.6-20210523(2021-05-23)
|
||||
- 秋云图表组件 修复小程序端开启滚动条更新数据后滚动条位置不符合预期的bug
|
||||
## 2.1.5-2021051702(2021-05-17)
|
||||
- uCharts.js 修复自定义Y轴min和max值为0时不能正确显示的bug
|
||||
## 2.1.5-20210517(2021-05-17)
|
||||
- uCharts.js 修复Y轴自定义min和max时,未按指定的最大值最小值显示坐标轴刻度的bug
|
||||
## 2.1.4-20210516(2021-05-16)
|
||||
- 秋云图表组件 优化onWindowResize防抖方法
|
||||
- 秋云图表组件 修复APP端uCharts更新数据时,清空series显示loading图标后再显示图表,图表抖动的bug
|
||||
- uCharts.js 修复开启canvas2d后,x轴、y轴、series自定义字体大小未按比例缩放的bug
|
||||
- 示例项目 修复format-e.vue拼写错误导致app端使用uCharts渲染图表
|
||||
## 2.1.3-20210513(2021-05-13)
|
||||
- 秋云图表组件 修改uCharts变更chartData数据为updateData方法,支持带滚动条的数据动态打点
|
||||
- 秋云图表组件 增加onWindowResize防抖方法 fix by ど誓言,如尘般染指流年づ
|
||||
- 秋云图表组件 H5或者APP变更chartData数据显示loading图表时,原数据闪现的bug
|
||||
- 秋云图表组件 props增加errorReload禁用错误点击重新加载的方法
|
||||
- uCharts.js 增加tooltip显示category(x轴对应点位)标题的功能,opts.extra.tooltip.showCategory,默认为false
|
||||
- uCharts.js 修复mix混合图只有柱状图时,tooltip的分割线显示位置不正确的bug
|
||||
- uCharts.js 修复开启滚动条,图表在拖动中动态打点,滚动条位置不正确的bug
|
||||
- uCharts.js 修复饼图类数据格式为echarts数据格式,series为空数组报错的bug
|
||||
- 示例项目 修改uCharts.js更新到v2.1.2版本后,@getIndex方法获取索引值变更为e.currentIndex.index
|
||||
- 示例项目 pages/updata/updata.vue增加滚动条拖动更新(数据动态打点)的demo
|
||||
- 示例项目 pages/other/other.vue增加errorReload禁用错误点击重新加载的demo
|
||||
## 2.1.2-20210509(2021-05-09)
|
||||
秋云图表组件 修复APP端初始化时就传入chartData或lacaldata不显示图表的bug
|
||||
## 2.1.1-20210509(2021-05-09)
|
||||
- 秋云图表组件 变更ECharts的eopts配置在renderjs内执行,支持在config-echarts.js配置文件内写function配置。
|
||||
- 秋云图表组件 修复APP端报错Prop being mutated: "onmouse"错误的bug。
|
||||
- 秋云图表组件 修复APP端报错Error: Not Found:Page[6][-1,27] at view.umd.min.js:1的bug。
|
||||
## 2.1.0-20210507(2021-05-07)
|
||||
- 秋云图表组件 修复初始化时就有数据或者数据更新的时候loading加载动画闪动的bug
|
||||
- uCharts.js 修复x轴format方法categories为字符串类型时返回NaN的bug
|
||||
- uCharts.js 修复series.textColor、legend.fontColor未执行全局默认颜色的bug
|
||||
## 2.1.0-20210506(2021-05-06)
|
||||
- 秋云图表组件 修复极个别情况下报错item.properties undefined的bug
|
||||
- 秋云图表组件 修复极个别情况下关闭加载动画reshow不起作用,无法显示图表的bug
|
||||
- 示例项目 pages/ucharts/ucharts.vue 增加时间轴折线图(type="tline")、时间轴区域图(type="tarea")、散点图(type="scatter")、气泡图demo(type="bubble")、倒三角形漏斗图(opts.extra.funnel.type="triangle")、金字塔形漏斗图(opts.extra.funnel.type="pyramid")
|
||||
- 示例项目 pages/format-u/format-u.vue 增加X轴format格式化示例
|
||||
- uCharts.js 升级至v2.1.0版本
|
||||
- uCharts.js 修复 玫瑰图面积模式点击tooltip位置不正确的bug
|
||||
- uCharts.js 修复 玫瑰图点击图例,只剩一个类别显示空白的bug
|
||||
- uCharts.js 修复 饼图类图点击图例,其他图表tooltip位置某些情况下不准的bug
|
||||
- uCharts.js 修复 x轴为矢量轴(时间轴)情况下,点击tooltip位置不正确的bug
|
||||
- uCharts.js 修复 词云图获取点击索引偶尔不准的bug
|
||||
- uCharts.js 增加 直角坐标系图表X轴format格式化方法(原生uCharts.js用法请使用formatter)
|
||||
- uCharts.js 增加 漏斗图扩展配置,倒三角形(opts.extra.funnel.type="triangle"),金字塔形(opts.extra.funnel.type="pyramid")
|
||||
- uCharts.js 增加 散点图(opts.type="scatter")、气泡图(opts.type="bubble")
|
||||
- 后期计划 完善散点图、气泡图,增加markPoints标记点,增加横向条状图。
|
||||
## 2.0.0-20210502(2021-05-02)
|
||||
- uCharts.js 修复词云图获取点击索引不正确的bug
|
||||
## 2.0.0-20210501(2021-05-01)
|
||||
- 秋云图表组件 修复QQ小程序、百度小程序在关闭动画效果情况下,v-for循环使用图表,显示不正确的bug
|
||||
## 2.0.0-20210426(2021-04-26)
|
||||
- 秋云图表组件 修复QQ小程序不支持canvas2d的bug
|
||||
- 秋云图表组件 修复钉钉小程序某些情况点击坐标计算错误的bug
|
||||
- uCharts.js 增加 extra.column.categoryGap 参数,柱状图类每个category点位(X轴点)柱子组之间的间距
|
||||
- uCharts.js 增加 yAxis.data[i].titleOffsetY 参数,标题纵向偏移距离,负数为向上偏移,正数向下偏移
|
||||
- uCharts.js 增加 yAxis.data[i].titleOffsetX 参数,标题横向偏移距离,负数为向左偏移,正数向右偏移
|
||||
- uCharts.js 增加 extra.gauge.labelOffset 参数,仪表盘标签文字径向便宜距离,默认13px
|
||||
## 2.0.0-20210422-2(2021-04-22)
|
||||
秋云图表组件 修复 formatterAssign 未判断 args[key] == null 的情况导致栈溢出的 bug
|
||||
## 2.0.0-20210422(2021-04-22)
|
||||
- 秋云图表组件 修复H5、APP、支付宝小程序、微信小程序canvas2d模式下横屏模式的bug
|
||||
## 2.0.0-20210421(2021-04-21)
|
||||
- uCharts.js 修复多行图例的情况下,图例在上方或者下方时,图例float为左侧或者右侧时,第二行及以后的图例对齐方式不正确的bug
|
||||
## 2.0.0-20210420(2021-04-20)
|
||||
- 秋云图表组件 修复微信小程序开启canvas2d模式后,windows版微信小程序不支持canvas2d模式的bug
|
||||
- 秋云图表组件 修改非uni_modules版本为v2.0版本qiun-data-charts组件
|
||||
## 2.0.0-20210419(2021-04-19)
|
||||
## v1.0版本已停更,建议转uni_modules版本组件方式调用,点击右侧绿色【使用HBuilderX导入插件】即可使用,示例项目请点击右侧蓝色按钮【使用HBuilderX导入示例项目】。
|
||||
## 初次使用如果提示未注册<qiun-data-charts>组件,请重启HBuilderX,如仍不好用,请重启电脑;
|
||||
## 如果是cli项目,请尝试清理node_modules,重新install,还不行就删除项目,再重新install。
|
||||
## 此问题已于DCloud官方确认,HBuilderX下个版本会修复。
|
||||
## 其他图表不显示问题详见[常见问题选项卡](https://demo.ucharts.cn)
|
||||
## <font color=#FF0000> 新手请先完整阅读帮助文档及常见问题3遍,右侧蓝色按钮示例项目请看2遍! </font>
|
||||
## [DEMO演示及在线生成工具(v2.0文档)https://demo.ucharts.cn](https://demo.ucharts.cn)
|
||||
## [图表组件在项目中的应用参见 UReport数据报表](https://ext.dcloud.net.cn/plugin?id=4651)
|
||||
- uCharts.js 修复混合图中柱状图单独设置颜色不生效的bug
|
||||
- uCharts.js 修复多Y轴单独设置fontSize时,开启canvas2d后,未对应放大字体的bug
|
||||
## 2.0.0-20210418(2021-04-18)
|
||||
- 秋云图表组件 增加directory配置,修复H5端history模式下如果发布到二级目录无法正确加载echarts.min.js的bug
|
||||
## 2.0.0-20210416(2021-04-16)
|
||||
## v1.0版本已停更,建议转uni_modules版本组件方式调用,点击右侧绿色【使用HBuilderX导入插件】即可使用,示例项目请点击右侧蓝色按钮【使用HBuilderX导入示例项目】。
|
||||
## 初次使用如果提示未注册<qiun-data-charts>组件,请重启HBuilderX,如仍不好用,请重启电脑;
|
||||
## 如果是cli项目,请尝试清理node_modules,重新install,还不行就删除项目,再重新install。
|
||||
## 此问题已于DCloud官方确认,HBuilderX下个版本会修复。
|
||||
## 其他图表不显示问题详见[常见问题选项卡](https://demo.ucharts.cn)
|
||||
## <font color=#FF0000> 新手请先完整阅读帮助文档及常见问题3遍,右侧蓝色按钮示例项目请看2遍! </font>
|
||||
## [DEMO演示及在线生成工具(v2.0文档)https://demo.ucharts.cn](https://demo.ucharts.cn)
|
||||
## [图表组件在项目中的应用参见 UReport数据报表](https://ext.dcloud.net.cn/plugin?id=4651)
|
||||
- 秋云图表组件 修复APP端某些情况下报错`Not Found Page`的bug,fix by 高级bug开发技术员
|
||||
- 示例项目 修复APP端v-for循环某些情况下报错`Not Found Page`的bug,fix by 高级bug开发技术员
|
||||
- uCharts.js 修复非直角坐标系tooltip提示窗右侧超出未变换方向显示的bug
|
||||
## 2.0.0-20210415(2021-04-15)
|
||||
- 秋云图表组件 修复H5端发布到二级目录下echarts无法加载的bug
|
||||
- 秋云图表组件 修复某些情况下echarts.off('finished')移除监听事件报错的bug
|
||||
## 2.0.0-20210414(2021-04-14)
|
||||
## v1.0版本已停更,建议转uni_modules版本组件方式调用,点击右侧绿色【使用HBuilderX导入插件】即可使用,示例项目请点击右侧蓝色按钮【使用HBuilderX导入示例项目】。
|
||||
## 初次使用如果提示未注册<qiun-data-charts>组件,请重启HBuilderX,如仍不好用,请重启电脑;
|
||||
## 如果是cli项目,请尝试清理node_modules,重新install,还不行就删除项目,再重新install。
|
||||
## 此问题已于DCloud官方确认,HBuilderX下个版本会修复。
|
||||
## 其他图表不显示问题详见[常见问题选项卡](https://demo.ucharts.cn)
|
||||
## <font color=#FF0000> 新手请先完整阅读帮助文档及常见问题3遍,右侧蓝色按钮示例项目请看2遍! </font>
|
||||
## [DEMO演示及在线生成工具(v2.0文档)https://demo.ucharts.cn](https://demo.ucharts.cn)
|
||||
## [图表组件在项目中的应用参见 UReport数据报表](https://ext.dcloud.net.cn/plugin?id=4651)
|
||||
- 秋云图表组件 修复H5端在cli项目下ECharts引用地址错误的bug
|
||||
- 示例项目 增加ECharts的formatter用法的示例(详见示例项目format-e.vue)
|
||||
- uCharts.js 增加圆环图中心背景色的配置extra.ring.centerColor
|
||||
- uCharts.js 修复微信小程序安卓端柱状图开启透明色后显示不正确的bug
|
||||
## 2.0.0-20210413(2021-04-13)
|
||||
- 秋云图表组件 修复百度小程序多个图表真机未能正确获取根元素dom尺寸的bug
|
||||
- 秋云图表组件 修复百度小程序横屏模式方向不正确的bug
|
||||
- 秋云图表组件 修改ontouch时,@getTouchStart@getTouchMove@getTouchEnd的触发条件
|
||||
- uCharts.js 修复饼图类数据格式series属性不生效的bug
|
||||
- uCharts.js 增加时序区域图 详见示例项目中ucharts.vue
|
||||
## 2.0.0-20210412-2(2021-04-12)
|
||||
## v1.0版本已停更,建议转uni_modules版本组件方式调用,点击右侧绿色【使用HBuilderX导入插件】即可使用,示例项目请点击右侧蓝色按钮【使用HBuilderX导入示例项目】。
|
||||
## 初次使用如果提示未注册<qiun-data-charts>组件,请重启HBuilderX。如仍不好用,请重启电脑,此问题已于DCloud官方确认,HBuilderX下个版本会修复。
|
||||
## [DEMO演示及在线生成工具(v2.0文档)https://demo.ucharts.cn](https://demo.ucharts.cn)
|
||||
## [图表组件在uniCloudAdmin中的应用 UReport数据报表](https://ext.dcloud.net.cn/plugin?id=4651)
|
||||
- 秋云图表组件 修复uCharts在APP端横屏模式下不能正确渲染的bug
|
||||
- 示例项目 增加ECharts柱状图渐变色、圆角柱状图、横向柱状图(条状图)的示例
|
||||
## 2.0.0-20210412(2021-04-12)
|
||||
- 秋云图表组件 修复created中判断echarts导致APP端无法识别,改回mounted中判断echarts初始化
|
||||
- uCharts.js 修复2d模式下series.textOffset未乘像素比的bug
|
||||
## 2.0.0-20210411(2021-04-11)
|
||||
## v1.0版本已停更,建议转uni_modules版本组件方式调用,点击右侧绿色【使用HBuilderX导入插件】即可使用,示例项目请点击右侧蓝色按钮【使用HBuilderX导入示例项目】。
|
||||
## 初次使用如果提示未注册<qiun-data-charts>组件,请重启HBuilderX,并清空小程序开发者工具缓存。
|
||||
## [DEMO演示及在线生成工具(v2.0文档)https://demo.ucharts.cn](https://demo.ucharts.cn)
|
||||
## [图表组件在uniCloudAdmin中的应用 UReport数据报表](https://ext.dcloud.net.cn/plugin?id=4651)
|
||||
- uCharts.js 折线图区域图增加connectNulls断点续连的功能,详见示例项目中ucharts.vue
|
||||
- 秋云图表组件 变更初始化方法为created,变更type2d默认值为true,优化2d模式下组件初始化后dom获取不到的bug
|
||||
- 秋云图表组件 修复左右布局时,右侧图表点击坐标错误的bug,修复tooltip柱状图自定义颜色显示object的bug
|
||||
## 2.0.0-20210410(2021-04-10)
|
||||
- 修复左右布局时,右侧图表点击坐标错误的bug,修复柱状图自定义颜色tooltip显示object的bug
|
||||
- 增加标记线及柱状图自定义颜色的demo
|
||||
## 2.0.0-20210409(2021-04-08)
|
||||
## v1.0版本已停更,建议转uni_modules版本组件方式调用,点击右侧【使用HBuilderX导入插件】即可体验,DEMO演示及在线生成工具(v2.0文档)[https://demo.ucharts.cn](https://demo.ucharts.cn)
|
||||
## 图表组件在uniCloudAdmin中的应用 [UReport数据报表](https://ext.dcloud.net.cn/plugin?id=4651)
|
||||
- uCharts.js 修复钉钉小程序百度小程序measureText不准确的bug,修复2d模式下饼图类activeRadius为按比例放大的bug
|
||||
- 修复组件在支付宝小程序端点击位置不准确的bug
|
||||
## 2.0.0-20210408(2021-04-07)
|
||||
- 修复组件在支付宝小程序端不能显示的bug(目前支付宝小程不能点击交互,后续修复)
|
||||
- uCharts.js 修复高分屏下柱状图类,圆弧进度条 自定义宽度不能按比例放大的bug
|
||||
## 2.0.0-20210407(2021-04-06)
|
||||
## v1.0版本已停更,建议转uni_modules版本组件方式调用,点击右侧【使用HBuilderX导入插件】即可体验,DEMO演示及在线生成工具(v2.0文档)[https://demo.ucharts.cn](https://demo.ucharts.cn)
|
||||
## 增加 通过tofix和unit快速格式化y轴的demo add by `howcode`
|
||||
## 增加 图表组件在uniCloudAdmin中的应用 [UReport数据报表](https://ext.dcloud.net.cn/plugin?id=4651)
|
||||
## 2.0.0-20210406(2021-04-05)
|
||||
# 秋云图表组件+uCharts v2.0版本同步上线,使用方法详见https://demo.ucharts.cn帮助页
|
||||
## 2.0.0(2021-04-05)
|
||||
# 秋云图表组件+uCharts v2.0版本同步上线,使用方法详见https://demo.ucharts.cn帮助页
|
||||
File diff suppressed because it is too large
Load Diff
File diff suppressed because one or more lines are too long
@@ -0,0 +1,162 @@
|
||||
<template>
|
||||
<view class="container loading1">
|
||||
<view class="shape shape1"></view>
|
||||
<view class="shape shape2"></view>
|
||||
<view class="shape shape3"></view>
|
||||
<view class="shape shape4"></view>
|
||||
</view>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
export default {
|
||||
name: 'loading1',
|
||||
data() {
|
||||
return {
|
||||
|
||||
};
|
||||
}
|
||||
}
|
||||
</script>
|
||||
|
||||
<style scoped="true">
|
||||
.container {
|
||||
width: 30px;
|
||||
height: 30px;
|
||||
position: relative;
|
||||
}
|
||||
.container.loading1 {
|
||||
-webkit-transform: rotate(45deg);
|
||||
transform: rotate(45deg);
|
||||
}
|
||||
|
||||
.container .shape {
|
||||
position: absolute;
|
||||
width: 10px;
|
||||
height: 10px;
|
||||
border-radius: 1px;
|
||||
}
|
||||
.container .shape.shape1 {
|
||||
left: 0;
|
||||
background-color: #1890FF;
|
||||
}
|
||||
.container .shape.shape2 {
|
||||
right: 0;
|
||||
background-color: #91CB74;
|
||||
}
|
||||
.container .shape.shape3 {
|
||||
bottom: 0;
|
||||
background-color: #FAC858;
|
||||
}
|
||||
.container .shape.shape4 {
|
||||
bottom: 0;
|
||||
right: 0;
|
||||
background-color: #EE6666;
|
||||
}
|
||||
|
||||
.loading1 .shape1 {
|
||||
-webkit-animation: animation1shape1 0.5s ease 0s infinite alternate;
|
||||
animation: animation1shape1 0.5s ease 0s infinite alternate;
|
||||
}
|
||||
|
||||
@-webkit-keyframes animation1shape1 {
|
||||
from {
|
||||
-webkit-transform: translate(0, 0);
|
||||
transform: translate(0, 0);
|
||||
}
|
||||
to {
|
||||
-webkit-transform: translate(16px, 16px);
|
||||
transform: translate(16px, 16px);
|
||||
}
|
||||
}
|
||||
|
||||
@keyframes animation1shape1 {
|
||||
from {
|
||||
-webkit-transform: translate(0, 0);
|
||||
transform: translate(0, 0);
|
||||
}
|
||||
to {
|
||||
-webkit-transform: translate(16px, 16px);
|
||||
transform: translate(16px, 16px);
|
||||
}
|
||||
}
|
||||
.loading1 .shape2 {
|
||||
-webkit-animation: animation1shape2 0.5s ease 0s infinite alternate;
|
||||
animation: animation1shape2 0.5s ease 0s infinite alternate;
|
||||
}
|
||||
|
||||
@-webkit-keyframes animation1shape2 {
|
||||
from {
|
||||
-webkit-transform: translate(0, 0);
|
||||
transform: translate(0, 0);
|
||||
}
|
||||
to {
|
||||
-webkit-transform: translate(-16px, 16px);
|
||||
transform: translate(-16px, 16px);
|
||||
}
|
||||
}
|
||||
|
||||
@keyframes animation1shape2 {
|
||||
from {
|
||||
-webkit-transform: translate(0, 0);
|
||||
transform: translate(0, 0);
|
||||
}
|
||||
to {
|
||||
-webkit-transform: translate(-16px, 16px);
|
||||
transform: translate(-16px, 16px);
|
||||
}
|
||||
}
|
||||
.loading1 .shape3 {
|
||||
-webkit-animation: animation1shape3 0.5s ease 0s infinite alternate;
|
||||
animation: animation1shape3 0.5s ease 0s infinite alternate;
|
||||
}
|
||||
|
||||
@-webkit-keyframes animation1shape3 {
|
||||
from {
|
||||
-webkit-transform: translate(0, 0);
|
||||
transform: translate(0, 0);
|
||||
}
|
||||
to {
|
||||
-webkit-transform: translate(16px, -16px);
|
||||
transform: translate(16px, -16px);
|
||||
}
|
||||
}
|
||||
|
||||
@keyframes animation1shape3 {
|
||||
from {
|
||||
-webkit-transform: translate(0, 0);
|
||||
transform: translate(0, 0);
|
||||
}
|
||||
to {
|
||||
-webkit-transform: translate(16px, -16px);
|
||||
transform: translate(16px, -16px);
|
||||
}
|
||||
}
|
||||
.loading1 .shape4 {
|
||||
-webkit-animation: animation1shape4 0.5s ease 0s infinite alternate;
|
||||
animation: animation1shape4 0.5s ease 0s infinite alternate;
|
||||
}
|
||||
|
||||
@-webkit-keyframes animation1shape4 {
|
||||
from {
|
||||
-webkit-transform: translate(0, 0);
|
||||
transform: translate(0, 0);
|
||||
}
|
||||
to {
|
||||
-webkit-transform: translate(-16px, -16px);
|
||||
transform: translate(-16px, -16px);
|
||||
}
|
||||
}
|
||||
|
||||
@keyframes animation1shape4 {
|
||||
from {
|
||||
-webkit-transform: translate(0, 0);
|
||||
transform: translate(0, 0);
|
||||
}
|
||||
to {
|
||||
-webkit-transform: translate(-16px, -16px);
|
||||
transform: translate(-16px, -16px);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
</style>
|
||||
@@ -0,0 +1,170 @@
|
||||
<template>
|
||||
<view class="container loading2">
|
||||
<view class="shape shape1"></view>
|
||||
<view class="shape shape2"></view>
|
||||
<view class="shape shape3"></view>
|
||||
<view class="shape shape4"></view>
|
||||
</view>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
export default {
|
||||
name: 'loading2',
|
||||
data() {
|
||||
return {
|
||||
|
||||
};
|
||||
}
|
||||
}
|
||||
</script>
|
||||
|
||||
<style scoped="true">
|
||||
.container {
|
||||
width: 30px;
|
||||
height: 30px;
|
||||
position: relative;
|
||||
}
|
||||
|
||||
.container.loading2 {
|
||||
-webkit-transform: rotate(10deg);
|
||||
transform: rotate(10deg);
|
||||
}
|
||||
.container.loading2 .shape {
|
||||
border-radius: 5px;
|
||||
}
|
||||
.container.loading2{
|
||||
-webkit-animation: rotation 1s infinite;
|
||||
animation: rotation 1s infinite;
|
||||
}
|
||||
|
||||
.container .shape {
|
||||
position: absolute;
|
||||
width: 10px;
|
||||
height: 10px;
|
||||
border-radius: 1px;
|
||||
}
|
||||
.container .shape.shape1 {
|
||||
left: 0;
|
||||
background-color: #1890FF;
|
||||
}
|
||||
.container .shape.shape2 {
|
||||
right: 0;
|
||||
background-color: #91CB74;
|
||||
}
|
||||
.container .shape.shape3 {
|
||||
bottom: 0;
|
||||
background-color: #FAC858;
|
||||
}
|
||||
.container .shape.shape4 {
|
||||
bottom: 0;
|
||||
right: 0;
|
||||
background-color: #EE6666;
|
||||
}
|
||||
|
||||
|
||||
.loading2 .shape1 {
|
||||
-webkit-animation: animation2shape1 0.5s ease 0s infinite alternate;
|
||||
animation: animation2shape1 0.5s ease 0s infinite alternate;
|
||||
}
|
||||
|
||||
@-webkit-keyframes animation2shape1 {
|
||||
from {
|
||||
-webkit-transform: translate(0, 0);
|
||||
transform: translate(0, 0);
|
||||
}
|
||||
to {
|
||||
-webkit-transform: translate(20px, 20px);
|
||||
transform: translate(20px, 20px);
|
||||
}
|
||||
}
|
||||
|
||||
@keyframes animation2shape1 {
|
||||
from {
|
||||
-webkit-transform: translate(0, 0);
|
||||
transform: translate(0, 0);
|
||||
}
|
||||
to {
|
||||
-webkit-transform: translate(20px, 20px);
|
||||
transform: translate(20px, 20px);
|
||||
}
|
||||
}
|
||||
.loading2 .shape2 {
|
||||
-webkit-animation: animation2shape2 0.5s ease 0s infinite alternate;
|
||||
animation: animation2shape2 0.5s ease 0s infinite alternate;
|
||||
}
|
||||
|
||||
@-webkit-keyframes animation2shape2 {
|
||||
from {
|
||||
-webkit-transform: translate(0, 0);
|
||||
transform: translate(0, 0);
|
||||
}
|
||||
to {
|
||||
-webkit-transform: translate(-20px, 20px);
|
||||
transform: translate(-20px, 20px);
|
||||
}
|
||||
}
|
||||
|
||||
@keyframes animation2shape2 {
|
||||
from {
|
||||
-webkit-transform: translate(0, 0);
|
||||
transform: translate(0, 0);
|
||||
}
|
||||
to {
|
||||
-webkit-transform: translate(-20px, 20px);
|
||||
transform: translate(-20px, 20px);
|
||||
}
|
||||
}
|
||||
.loading2 .shape3 {
|
||||
-webkit-animation: animation2shape3 0.5s ease 0s infinite alternate;
|
||||
animation: animation2shape3 0.5s ease 0s infinite alternate;
|
||||
}
|
||||
|
||||
@-webkit-keyframes animation2shape3 {
|
||||
from {
|
||||
-webkit-transform: translate(0, 0);
|
||||
transform: translate(0, 0);
|
||||
}
|
||||
to {
|
||||
-webkit-transform: translate(20px, -20px);
|
||||
transform: translate(20px, -20px);
|
||||
}
|
||||
}
|
||||
|
||||
@keyframes animation2shape3 {
|
||||
from {
|
||||
-webkit-transform: translate(0, 0);
|
||||
transform: translate(0, 0);
|
||||
}
|
||||
to {
|
||||
-webkit-transform: translate(20px, -20px);
|
||||
transform: translate(20px, -20px);
|
||||
}
|
||||
}
|
||||
.loading2 .shape4 {
|
||||
-webkit-animation: animation2shape4 0.5s ease 0s infinite alternate;
|
||||
animation: animation2shape4 0.5s ease 0s infinite alternate;
|
||||
}
|
||||
|
||||
@-webkit-keyframes animation2shape4 {
|
||||
from {
|
||||
-webkit-transform: translate(0, 0);
|
||||
transform: translate(0, 0);
|
||||
}
|
||||
to {
|
||||
-webkit-transform: translate(-20px, -20px);
|
||||
transform: translate(-20px, -20px);
|
||||
}
|
||||
}
|
||||
|
||||
@keyframes animation2shape4 {
|
||||
from {
|
||||
-webkit-transform: translate(0, 0);
|
||||
transform: translate(0, 0);
|
||||
}
|
||||
to {
|
||||
-webkit-transform: translate(-20px, -20px);
|
||||
transform: translate(-20px, -20px);
|
||||
}
|
||||
}
|
||||
|
||||
</style>
|
||||
@@ -0,0 +1,173 @@
|
||||
<template>
|
||||
<view class="container loading3">
|
||||
<view class="shape shape1"></view>
|
||||
<view class="shape shape2"></view>
|
||||
<view class="shape shape3"></view>
|
||||
<view class="shape shape4"></view>
|
||||
</view>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
export default {
|
||||
name: 'loading3',
|
||||
data() {
|
||||
return {
|
||||
|
||||
};
|
||||
}
|
||||
}
|
||||
</script>
|
||||
|
||||
<style scoped="true">
|
||||
.container {
|
||||
width: 30px;
|
||||
height: 30px;
|
||||
position: relative;
|
||||
}
|
||||
|
||||
.container.loading3 {
|
||||
-webkit-animation: rotation 1s infinite;
|
||||
animation: rotation 1s infinite;
|
||||
}
|
||||
.container.loading3 .shape1 {
|
||||
border-top-left-radius: 10px;
|
||||
}
|
||||
.container.loading3 .shape2 {
|
||||
border-top-right-radius: 10px;
|
||||
}
|
||||
.container.loading3 .shape3 {
|
||||
border-bottom-left-radius: 10px;
|
||||
}
|
||||
.container.loading3 .shape4 {
|
||||
border-bottom-right-radius: 10px;
|
||||
}
|
||||
|
||||
.container .shape {
|
||||
position: absolute;
|
||||
width: 10px;
|
||||
height: 10px;
|
||||
border-radius: 1px;
|
||||
}
|
||||
.container .shape.shape1 {
|
||||
left: 0;
|
||||
background-color: #1890FF;
|
||||
}
|
||||
.container .shape.shape2 {
|
||||
right: 0;
|
||||
background-color: #91CB74;
|
||||
}
|
||||
.container .shape.shape3 {
|
||||
bottom: 0;
|
||||
background-color: #FAC858;
|
||||
}
|
||||
.container .shape.shape4 {
|
||||
bottom: 0;
|
||||
right: 0;
|
||||
background-color: #EE6666;
|
||||
}
|
||||
|
||||
.loading3 .shape1 {
|
||||
-webkit-animation: animation3shape1 0.5s ease 0s infinite alternate;
|
||||
animation: animation3shape1 0.5s ease 0s infinite alternate;
|
||||
}
|
||||
|
||||
@-webkit-keyframes animation3shape1 {
|
||||
from {
|
||||
-webkit-transform: translate(0, 0);
|
||||
transform: translate(0, 0);
|
||||
}
|
||||
to {
|
||||
-webkit-transform: translate(5px, 5px);
|
||||
transform: translate(5px, 5px);
|
||||
}
|
||||
}
|
||||
|
||||
@keyframes animation3shape1 {
|
||||
from {
|
||||
-webkit-transform: translate(0, 0);
|
||||
transform: translate(0, 0);
|
||||
}
|
||||
to {
|
||||
-webkit-transform: translate(5px, 5px);
|
||||
transform: translate(5px, 5px);
|
||||
}
|
||||
}
|
||||
.loading3 .shape2 {
|
||||
-webkit-animation: animation3shape2 0.5s ease 0s infinite alternate;
|
||||
animation: animation3shape2 0.5s ease 0s infinite alternate;
|
||||
}
|
||||
|
||||
@-webkit-keyframes animation3shape2 {
|
||||
from {
|
||||
-webkit-transform: translate(0, 0);
|
||||
transform: translate(0, 0);
|
||||
}
|
||||
to {
|
||||
-webkit-transform: translate(-5px, 5px);
|
||||
transform: translate(-5px, 5px);
|
||||
}
|
||||
}
|
||||
|
||||
@keyframes animation3shape2 {
|
||||
from {
|
||||
-webkit-transform: translate(0, 0);
|
||||
transform: translate(0, 0);
|
||||
}
|
||||
to {
|
||||
-webkit-transform: translate(-5px, 5px);
|
||||
transform: translate(-5px, 5px);
|
||||
}
|
||||
}
|
||||
.loading3 .shape3 {
|
||||
-webkit-animation: animation3shape3 0.5s ease 0s infinite alternate;
|
||||
animation: animation3shape3 0.5s ease 0s infinite alternate;
|
||||
}
|
||||
|
||||
@-webkit-keyframes animation3shape3 {
|
||||
from {
|
||||
-webkit-transform: translate(0, 0);
|
||||
transform: translate(0, 0);
|
||||
}
|
||||
to {
|
||||
-webkit-transform: translate(5px, -5px);
|
||||
transform: translate(5px, -5px);
|
||||
}
|
||||
}
|
||||
|
||||
@keyframes animation3shape3 {
|
||||
from {
|
||||
-webkit-transform: translate(0, 0);
|
||||
transform: translate(0, 0);
|
||||
}
|
||||
to {
|
||||
-webkit-transform: translate(5px, -5px);
|
||||
transform: translate(5px, -5px);
|
||||
}
|
||||
}
|
||||
.loading3 .shape4 {
|
||||
-webkit-animation: animation3shape4 0.5s ease 0s infinite alternate;
|
||||
animation: animation3shape4 0.5s ease 0s infinite alternate;
|
||||
}
|
||||
|
||||
@-webkit-keyframes animation3shape4 {
|
||||
from {
|
||||
-webkit-transform: translate(0, 0);
|
||||
transform: translate(0, 0);
|
||||
}
|
||||
to {
|
||||
-webkit-transform: translate(-5px, -5px);
|
||||
transform: translate(-5px, -5px);
|
||||
}
|
||||
}
|
||||
|
||||
@keyframes animation3shape4 {
|
||||
from {
|
||||
-webkit-transform: translate(0, 0);
|
||||
transform: translate(0, 0);
|
||||
}
|
||||
to {
|
||||
-webkit-transform: translate(-5px, -5px);
|
||||
transform: translate(-5px, -5px);
|
||||
}
|
||||
}
|
||||
</style>
|
||||
@@ -0,0 +1,222 @@
|
||||
<template>
|
||||
<view class="container loading5">
|
||||
<view class="shape shape1"></view>
|
||||
<view class="shape shape2"></view>
|
||||
<view class="shape shape3"></view>
|
||||
<view class="shape shape4"></view>
|
||||
</view>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
export default {
|
||||
name: 'loading5',
|
||||
data() {
|
||||
return {
|
||||
|
||||
};
|
||||
}
|
||||
}
|
||||
</script>
|
||||
|
||||
<style scoped="true">
|
||||
.container {
|
||||
width: 30px;
|
||||
height: 30px;
|
||||
position: relative;
|
||||
}
|
||||
|
||||
.container.loading5 .shape {
|
||||
width: 15px;
|
||||
height: 15px;
|
||||
}
|
||||
|
||||
.container .shape {
|
||||
position: absolute;
|
||||
width: 10px;
|
||||
height: 10px;
|
||||
border-radius: 1px;
|
||||
}
|
||||
.container .shape.shape1 {
|
||||
left: 0;
|
||||
background-color: #1890FF;
|
||||
}
|
||||
.container .shape.shape2 {
|
||||
right: 0;
|
||||
background-color: #91CB74;
|
||||
}
|
||||
.container .shape.shape3 {
|
||||
bottom: 0;
|
||||
background-color: #FAC858;
|
||||
}
|
||||
.container .shape.shape4 {
|
||||
bottom: 0;
|
||||
right: 0;
|
||||
background-color: #EE6666;
|
||||
}
|
||||
|
||||
.loading5 .shape1 {
|
||||
animation: animation5shape1 2s ease 0s infinite reverse;
|
||||
}
|
||||
|
||||
@-webkit-keyframes animation5shape1 {
|
||||
0% {
|
||||
-webkit-transform: translate(0, 0);
|
||||
transform: translate(0, 0);
|
||||
}
|
||||
25% {
|
||||
-webkit-transform: translate(0, 15px);
|
||||
transform: translate(0, 15px);
|
||||
}
|
||||
50% {
|
||||
-webkit-transform: translate(15px, 15px);
|
||||
transform: translate(15px, 15px);
|
||||
}
|
||||
75% {
|
||||
-webkit-transform: translate(15px, 0);
|
||||
transform: translate(15px, 0);
|
||||
}
|
||||
}
|
||||
|
||||
@keyframes animation5shape1 {
|
||||
0% {
|
||||
-webkit-transform: translate(0, 0);
|
||||
transform: translate(0, 0);
|
||||
}
|
||||
25% {
|
||||
-webkit-transform: translate(0, 15px);
|
||||
transform: translate(0, 15px);
|
||||
}
|
||||
50% {
|
||||
-webkit-transform: translate(15px, 15px);
|
||||
transform: translate(15px, 15px);
|
||||
}
|
||||
75% {
|
||||
-webkit-transform: translate(15px, 0);
|
||||
transform: translate(15px, 0);
|
||||
}
|
||||
}
|
||||
.loading5 .shape2 {
|
||||
animation: animation5shape2 2s ease 0s infinite reverse;
|
||||
}
|
||||
|
||||
@-webkit-keyframes animation5shape2 {
|
||||
0% {
|
||||
-webkit-transform: translate(0, 0);
|
||||
transform: translate(0, 0);
|
||||
}
|
||||
25% {
|
||||
-webkit-transform: translate(-15px, 0);
|
||||
transform: translate(-15px, 0);
|
||||
}
|
||||
50% {
|
||||
-webkit-transform: translate(-15px, 15px);
|
||||
transform: translate(-15px, 15px);
|
||||
}
|
||||
75% {
|
||||
-webkit-transform: translate(0, 15px);
|
||||
transform: translate(0, 15px);
|
||||
}
|
||||
}
|
||||
|
||||
@keyframes animation5shape2 {
|
||||
0% {
|
||||
-webkit-transform: translate(0, 0);
|
||||
transform: translate(0, 0);
|
||||
}
|
||||
25% {
|
||||
-webkit-transform: translate(-15px, 0);
|
||||
transform: translate(-15px, 0);
|
||||
}
|
||||
50% {
|
||||
-webkit-transform: translate(-15px, 15px);
|
||||
transform: translate(-15px, 15px);
|
||||
}
|
||||
75% {
|
||||
-webkit-transform: translate(0, 15px);
|
||||
transform: translate(0, 15px);
|
||||
}
|
||||
}
|
||||
.loading5 .shape3 {
|
||||
animation: animation5shape3 2s ease 0s infinite reverse;
|
||||
}
|
||||
|
||||
@-webkit-keyframes animation5shape3 {
|
||||
0% {
|
||||
-webkit-transform: translate(0, 0);
|
||||
transform: translate(0, 0);
|
||||
}
|
||||
25% {
|
||||
-webkit-transform: translate(15px, 0);
|
||||
transform: translate(15px, 0);
|
||||
}
|
||||
50% {
|
||||
-webkit-transform: translate(15px, -15px);
|
||||
transform: translate(15px, -15px);
|
||||
}
|
||||
75% {
|
||||
-webkit-transform: translate(0, -15px);
|
||||
transform: translate(0, -15px);
|
||||
}
|
||||
}
|
||||
|
||||
@keyframes animation5shape3 {
|
||||
0% {
|
||||
-webkit-transform: translate(0, 0);
|
||||
transform: translate(0, 0);
|
||||
}
|
||||
25% {
|
||||
-webkit-transform: translate(15px, 0);
|
||||
transform: translate(15px, 0);
|
||||
}
|
||||
50% {
|
||||
-webkit-transform: translate(15px, -15px);
|
||||
transform: translate(15px, -15px);
|
||||
}
|
||||
75% {
|
||||
-webkit-transform: translate(0, -15px);
|
||||
transform: translate(0, -15px);
|
||||
}
|
||||
}
|
||||
.loading5 .shape4 {
|
||||
animation: animation5shape4 2s ease 0s infinite reverse;
|
||||
}
|
||||
|
||||
@-webkit-keyframes animation5shape4 {
|
||||
0% {
|
||||
-webkit-transform: translate(0, 0);
|
||||
transform: translate(0, 0);
|
||||
}
|
||||
25% {
|
||||
-webkit-transform: translate(0, -15px);
|
||||
transform: translate(0, -15px);
|
||||
}
|
||||
50% {
|
||||
-webkit-transform: translate(-15px, -15px);
|
||||
transform: translate(-15px, -15px);
|
||||
}
|
||||
75% {
|
||||
-webkit-transform: translate(-15px, 0);
|
||||
transform: translate(-15px, 0);
|
||||
}
|
||||
}
|
||||
|
||||
@keyframes animation5shape4 {
|
||||
0% {
|
||||
-webkit-transform: translate(0, 0);
|
||||
transform: translate(0, 0);
|
||||
}
|
||||
25% {
|
||||
-webkit-transform: translate(0, -15px);
|
||||
transform: translate(0, -15px);
|
||||
}
|
||||
50% {
|
||||
-webkit-transform: translate(-15px, -15px);
|
||||
transform: translate(-15px, -15px);
|
||||
}
|
||||
75% {
|
||||
-webkit-transform: translate(-15px, 0);
|
||||
transform: translate(-15px, 0);
|
||||
}
|
||||
}
|
||||
|
||||
</style>
|
||||
@@ -0,0 +1,229 @@
|
||||
<template>
|
||||
<view class="container loading6">
|
||||
<view class="shape shape1"></view>
|
||||
<view class="shape shape2"></view>
|
||||
<view class="shape shape3"></view>
|
||||
<view class="shape shape4"></view>
|
||||
</view>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
export default {
|
||||
name: 'loading6',
|
||||
data() {
|
||||
return {
|
||||
|
||||
};
|
||||
}
|
||||
}
|
||||
</script>
|
||||
<style scoped="true">
|
||||
.container {
|
||||
width: 30px;
|
||||
height: 30px;
|
||||
position: relative;
|
||||
}
|
||||
|
||||
.container.loading6 {
|
||||
-webkit-animation: rotation 1s infinite;
|
||||
animation: rotation 1s infinite;
|
||||
}
|
||||
.container.loading6 .shape {
|
||||
width: 12px;
|
||||
height: 12px;
|
||||
border-radius: 2px;
|
||||
}
|
||||
.container .shape {
|
||||
position: absolute;
|
||||
width: 10px;
|
||||
height: 10px;
|
||||
border-radius: 1px;
|
||||
}
|
||||
.container .shape.shape1 {
|
||||
left: 0;
|
||||
background-color: #1890FF;
|
||||
}
|
||||
.container .shape.shape2 {
|
||||
right: 0;
|
||||
background-color: #91CB74;
|
||||
}
|
||||
.container .shape.shape3 {
|
||||
bottom: 0;
|
||||
background-color: #FAC858;
|
||||
}
|
||||
.container .shape.shape4 {
|
||||
bottom: 0;
|
||||
right: 0;
|
||||
background-color: #EE6666;
|
||||
}
|
||||
|
||||
|
||||
.loading6 .shape1 {
|
||||
-webkit-animation: animation6shape1 2s linear 0s infinite normal;
|
||||
animation: animation6shape1 2s linear 0s infinite normal;
|
||||
}
|
||||
|
||||
@-webkit-keyframes animation6shape1 {
|
||||
0% {
|
||||
-webkit-transform: translate(0, 0);
|
||||
transform: translate(0, 0);
|
||||
}
|
||||
25% {
|
||||
-webkit-transform: translate(0, 18px);
|
||||
transform: translate(0, 18px);
|
||||
}
|
||||
50% {
|
||||
-webkit-transform: translate(18px, 18px);
|
||||
transform: translate(18px, 18px);
|
||||
}
|
||||
75% {
|
||||
-webkit-transform: translate(18px, 0);
|
||||
transform: translate(18px, 0);
|
||||
}
|
||||
}
|
||||
|
||||
@keyframes animation6shape1 {
|
||||
0% {
|
||||
-webkit-transform: translate(0, 0);
|
||||
transform: translate(0, 0);
|
||||
}
|
||||
25% {
|
||||
-webkit-transform: translate(0, 18px);
|
||||
transform: translate(0, 18px);
|
||||
}
|
||||
50% {
|
||||
-webkit-transform: translate(18px, 18px);
|
||||
transform: translate(18px, 18px);
|
||||
}
|
||||
75% {
|
||||
-webkit-transform: translate(18px, 0);
|
||||
transform: translate(18px, 0);
|
||||
}
|
||||
}
|
||||
.loading6 .shape2 {
|
||||
-webkit-animation: animation6shape2 2s linear 0s infinite normal;
|
||||
animation: animation6shape2 2s linear 0s infinite normal;
|
||||
}
|
||||
|
||||
@-webkit-keyframes animation6shape2 {
|
||||
0% {
|
||||
-webkit-transform: translate(0, 0);
|
||||
transform: translate(0, 0);
|
||||
}
|
||||
25% {
|
||||
-webkit-transform: translate(-18px, 0);
|
||||
transform: translate(-18px, 0);
|
||||
}
|
||||
50% {
|
||||
-webkit-transform: translate(-18px, 18px);
|
||||
transform: translate(-18px, 18px);
|
||||
}
|
||||
75% {
|
||||
-webkit-transform: translate(0, 18px);
|
||||
transform: translate(0, 18px);
|
||||
}
|
||||
}
|
||||
|
||||
@keyframes animation6shape2 {
|
||||
0% {
|
||||
-webkit-transform: translate(0, 0);
|
||||
transform: translate(0, 0);
|
||||
}
|
||||
25% {
|
||||
-webkit-transform: translate(-18px, 0);
|
||||
transform: translate(-18px, 0);
|
||||
}
|
||||
50% {
|
||||
-webkit-transform: translate(-18px, 18px);
|
||||
transform: translate(-18px, 18px);
|
||||
}
|
||||
75% {
|
||||
-webkit-transform: translate(0, 18px);
|
||||
transform: translate(0, 18px);
|
||||
}
|
||||
}
|
||||
.loading6 .shape3 {
|
||||
-webkit-animation: animation6shape3 2s linear 0s infinite normal;
|
||||
animation: animation6shape3 2s linear 0s infinite normal;
|
||||
}
|
||||
|
||||
@-webkit-keyframes animation6shape3 {
|
||||
0% {
|
||||
-webkit-transform: translate(0, 0);
|
||||
transform: translate(0, 0);
|
||||
}
|
||||
25% {
|
||||
-webkit-transform: translate(18px, 0);
|
||||
transform: translate(18px, 0);
|
||||
}
|
||||
50% {
|
||||
-webkit-transform: translate(18px, -18px);
|
||||
transform: translate(18px, -18px);
|
||||
}
|
||||
75% {
|
||||
-webkit-transform: translate(0, -18px);
|
||||
transform: translate(0, -18px);
|
||||
}
|
||||
}
|
||||
|
||||
@keyframes animation6shape3 {
|
||||
0% {
|
||||
-webkit-transform: translate(0, 0);
|
||||
transform: translate(0, 0);
|
||||
}
|
||||
25% {
|
||||
-webkit-transform: translate(18px, 0);
|
||||
transform: translate(18px, 0);
|
||||
}
|
||||
50% {
|
||||
-webkit-transform: translate(18px, -18px);
|
||||
transform: translate(18px, -18px);
|
||||
}
|
||||
75% {
|
||||
-webkit-transform: translate(0, -18px);
|
||||
transform: translate(0, -18px);
|
||||
}
|
||||
}
|
||||
.loading6 .shape4 {
|
||||
-webkit-animation: animation6shape4 2s linear 0s infinite normal;
|
||||
animation: animation6shape4 2s linear 0s infinite normal;
|
||||
}
|
||||
|
||||
@-webkit-keyframes animation6shape4 {
|
||||
0% {
|
||||
-webkit-transform: translate(0, 0);
|
||||
transform: translate(0, 0);
|
||||
}
|
||||
25% {
|
||||
-webkit-transform: translate(0, -18px);
|
||||
transform: translate(0, -18px);
|
||||
}
|
||||
50% {
|
||||
-webkit-transform: translate(-18px, -18px);
|
||||
transform: translate(-18px, -18px);
|
||||
}
|
||||
75% {
|
||||
-webkit-transform: translate(-18px, 0);
|
||||
transform: translate(-18px, 0);
|
||||
}
|
||||
}
|
||||
|
||||
@keyframes animation6shape4 {
|
||||
0% {
|
||||
-webkit-transform: translate(0, 0);
|
||||
transform: translate(0, 0);
|
||||
}
|
||||
25% {
|
||||
-webkit-transform: translate(0, -18px);
|
||||
transform: translate(0, -18px);
|
||||
}
|
||||
50% {
|
||||
-webkit-transform: translate(-18px, -18px);
|
||||
transform: translate(-18px, -18px);
|
||||
}
|
||||
75% {
|
||||
-webkit-transform: translate(-18px, 0);
|
||||
transform: translate(-18px, 0);
|
||||
}
|
||||
}
|
||||
</style>
|
||||
@@ -0,0 +1,36 @@
|
||||
<template>
|
||||
<view>
|
||||
<Loading1 v-if="loadingType==1"/>
|
||||
<Loading2 v-if="loadingType==2"/>
|
||||
<Loading3 v-if="loadingType==3"/>
|
||||
<Loading4 v-if="loadingType==4"/>
|
||||
<Loading5 v-if="loadingType==5"/>
|
||||
</view>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
import Loading1 from "./loading1.vue";
|
||||
import Loading2 from "./loading2.vue";
|
||||
import Loading3 from "./loading3.vue";
|
||||
import Loading4 from "./loading4.vue";
|
||||
import Loading5 from "./loading5.vue";
|
||||
export default {
|
||||
components:{Loading1,Loading2,Loading3,Loading4,Loading5},
|
||||
name: 'qiun-loading',
|
||||
props: {
|
||||
loadingType: {
|
||||
type: Number,
|
||||
default: 2
|
||||
},
|
||||
},
|
||||
data() {
|
||||
return {
|
||||
|
||||
};
|
||||
},
|
||||
}
|
||||
</script>
|
||||
|
||||
<style>
|
||||
|
||||
</style>
|
||||
@@ -0,0 +1,422 @@
|
||||
/*
|
||||
* uCharts®
|
||||
* 高性能跨平台图表库,支持H5、APP、小程序(微信/支付宝/百度/头条/QQ/360)、Vue、Taro等支持canvas的框架平台
|
||||
* Copyright (c) 2021 QIUN®秋云 https://www.ucharts.cn All rights reserved.
|
||||
* Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )
|
||||
* 复制使用请保留本段注释,感谢支持开源!
|
||||
*
|
||||
* uCharts®官方网站
|
||||
* https://www.uCharts.cn
|
||||
*
|
||||
* 开源地址:
|
||||
* https://gitee.com/uCharts/uCharts
|
||||
*
|
||||
* uni-app插件市场地址:
|
||||
* http://ext.dcloud.net.cn/plugin?id=271
|
||||
*
|
||||
*/
|
||||
|
||||
// 通用配置项
|
||||
|
||||
// 主题颜色配置:如每个图表类型需要不同主题,请在对应图表类型上更改color属性
|
||||
const color = ['#1890FF', '#91CB74', '#FAC858', '#EE6666', '#73C0DE', '#3CA272', '#FC8452', '#9A60B4', '#ea7ccc'];
|
||||
|
||||
const cfe = {
|
||||
//demotype为自定义图表类型
|
||||
"type": ["pie", "ring", "rose", "funnel", "line", "column", "area", "radar", "gauge","candle","demotype"],
|
||||
//增加自定义图表类型,如果需要categories,请在这里加入您的图表类型例如最后的"demotype"
|
||||
"categories": ["line", "column", "area", "radar", "gauge", "candle","demotype"],
|
||||
//instance为实例变量承载属性,option为eopts承载属性,不要删除
|
||||
"instance": {},
|
||||
"option": {},
|
||||
//下面是自定义format配置,因除H5端外的其他端无法通过props传递函数,只能通过此属性对应下标的方式来替换
|
||||
"formatter":{
|
||||
"tooltipDemo1":function(res){
|
||||
let result = ''
|
||||
for (let i in res) {
|
||||
if (i == 0) {
|
||||
result += res[i].axisValueLabel + '年销售额'
|
||||
}
|
||||
let value = '--'
|
||||
if (res[i].data !== null) {
|
||||
value = res[i].data
|
||||
}
|
||||
// #ifdef H5
|
||||
result += '\n' + res[i].seriesName + ':' + value + ' 万元'
|
||||
// #endif
|
||||
|
||||
// #ifdef APP-PLUS
|
||||
result += '<br/>' + res[i].marker + res[i].seriesName + ':' + value + ' 万元'
|
||||
// #endif
|
||||
}
|
||||
return result;
|
||||
},
|
||||
legendFormat:function(name){
|
||||
return "自定义图例+"+name;
|
||||
},
|
||||
yAxisFormatDemo:function (value, index) {
|
||||
return value + '元';
|
||||
},
|
||||
seriesFormatDemo:function(res){
|
||||
return res.name + '年' + res.value + '元';
|
||||
}
|
||||
},
|
||||
//这里演示了自定义您的图表类型的option,可以随意命名,之后在组件上 type="demotype" 后,组件会调用这个花括号里的option,如果组件上还存在eopts参数,会将demotype与eopts中option合并后渲染图表。
|
||||
"demotype":{
|
||||
"color": color,
|
||||
//在这里填写echarts的option即可
|
||||
|
||||
},
|
||||
//下面是自定义配置,请添加项目所需的通用配置
|
||||
"column": {
|
||||
"color": color,
|
||||
"title": {
|
||||
"text": ''
|
||||
},
|
||||
"tooltip": {
|
||||
"trigger": 'axis'
|
||||
},
|
||||
"grid": {
|
||||
"top": 30,
|
||||
"bottom": 50,
|
||||
"right": 15,
|
||||
"left": 40
|
||||
},
|
||||
"legend": {
|
||||
"bottom": 'left',
|
||||
},
|
||||
"toolbox": {
|
||||
"show": false,
|
||||
},
|
||||
"xAxis": {
|
||||
"type": 'category',
|
||||
"axisLabel": {
|
||||
"color": '#666666'
|
||||
},
|
||||
"axisLine": {
|
||||
"lineStyle": {
|
||||
"color": '#CCCCCC'
|
||||
}
|
||||
},
|
||||
"boundaryGap": true,
|
||||
"data": []
|
||||
},
|
||||
"yAxis": {
|
||||
"type": 'value',
|
||||
"axisTick": {
|
||||
"show": false,
|
||||
},
|
||||
"axisLabel": {
|
||||
"color": '#666666'
|
||||
},
|
||||
"axisLine": {
|
||||
"lineStyle": {
|
||||
"color": '#CCCCCC'
|
||||
}
|
||||
},
|
||||
},
|
||||
"seriesTemplate": {
|
||||
"name": '',
|
||||
"type": 'bar',
|
||||
"data": [],
|
||||
"barwidth": 20,
|
||||
"label": {
|
||||
"show": true,
|
||||
"color": "#666666",
|
||||
"position": 'top',
|
||||
},
|
||||
},
|
||||
},
|
||||
"line": {
|
||||
"color": color,
|
||||
"title": {
|
||||
"text": ''
|
||||
},
|
||||
"tooltip": {
|
||||
"trigger": 'axis'
|
||||
},
|
||||
"grid": {
|
||||
"top": 30,
|
||||
"bottom": 50,
|
||||
"right": 15,
|
||||
"left": 40
|
||||
},
|
||||
"legend": {
|
||||
"bottom": 'left',
|
||||
},
|
||||
"toolbox": {
|
||||
"show": false,
|
||||
},
|
||||
"xAxis": {
|
||||
"type": 'category',
|
||||
"axisLabel": {
|
||||
"color": '#666666'
|
||||
},
|
||||
"axisLine": {
|
||||
"lineStyle": {
|
||||
"color": '#CCCCCC'
|
||||
}
|
||||
},
|
||||
"boundaryGap": true,
|
||||
"data": []
|
||||
},
|
||||
"yAxis": {
|
||||
"type": 'value',
|
||||
"axisTick": {
|
||||
"show": false,
|
||||
},
|
||||
"axisLabel": {
|
||||
"color": '#666666'
|
||||
},
|
||||
"axisLine": {
|
||||
"lineStyle": {
|
||||
"color": '#CCCCCC'
|
||||
}
|
||||
},
|
||||
},
|
||||
"seriesTemplate": {
|
||||
"name": '',
|
||||
"type": 'line',
|
||||
"data": [],
|
||||
"barwidth": 20,
|
||||
"label": {
|
||||
"show": true,
|
||||
"color": "#666666",
|
||||
"position": 'top',
|
||||
},
|
||||
},
|
||||
},
|
||||
"area": {
|
||||
"color": color,
|
||||
"title": {
|
||||
"text": ''
|
||||
},
|
||||
"tooltip": {
|
||||
"trigger": 'axis'
|
||||
},
|
||||
"grid": {
|
||||
"top": 30,
|
||||
"bottom": 50,
|
||||
"right": 15,
|
||||
"left": 40
|
||||
},
|
||||
"legend": {
|
||||
"bottom": 'left',
|
||||
},
|
||||
"toolbox": {
|
||||
"show": false,
|
||||
},
|
||||
"xAxis": {
|
||||
"type": 'category',
|
||||
"axisLabel": {
|
||||
"color": '#666666'
|
||||
},
|
||||
"axisLine": {
|
||||
"lineStyle": {
|
||||
"color": '#CCCCCC'
|
||||
}
|
||||
},
|
||||
"boundaryGap": true,
|
||||
"data": []
|
||||
},
|
||||
"yAxis": {
|
||||
"type": 'value',
|
||||
"axisTick": {
|
||||
"show": false,
|
||||
},
|
||||
"axisLabel": {
|
||||
"color": '#666666'
|
||||
},
|
||||
"axisLine": {
|
||||
"lineStyle": {
|
||||
"color": '#CCCCCC'
|
||||
}
|
||||
},
|
||||
},
|
||||
"seriesTemplate": {
|
||||
"name": '',
|
||||
"type": 'line',
|
||||
"data": [],
|
||||
"areaStyle": {},
|
||||
"label": {
|
||||
"show": true,
|
||||
"color": "#666666",
|
||||
"position": 'top',
|
||||
},
|
||||
},
|
||||
},
|
||||
"pie": {
|
||||
"color": color,
|
||||
"title": {
|
||||
"text": ''
|
||||
},
|
||||
"tooltip": {
|
||||
"trigger": 'item'
|
||||
},
|
||||
"grid": {
|
||||
"top": 40,
|
||||
"bottom": 30,
|
||||
"right": 15,
|
||||
"left": 15
|
||||
},
|
||||
"legend": {
|
||||
"bottom": 'left',
|
||||
},
|
||||
"seriesTemplate": {
|
||||
"name": '',
|
||||
"type": 'pie',
|
||||
"data": [],
|
||||
"radius": '50%',
|
||||
"label": {
|
||||
"show": true,
|
||||
"color": "#666666",
|
||||
"position": 'top',
|
||||
},
|
||||
},
|
||||
},
|
||||
"ring": {
|
||||
"color": color,
|
||||
"title": {
|
||||
"text": ''
|
||||
},
|
||||
"tooltip": {
|
||||
"trigger": 'item'
|
||||
},
|
||||
"grid": {
|
||||
"top": 40,
|
||||
"bottom": 30,
|
||||
"right": 15,
|
||||
"left": 15
|
||||
},
|
||||
"legend": {
|
||||
"bottom": 'left',
|
||||
},
|
||||
"seriesTemplate": {
|
||||
"name": '',
|
||||
"type": 'pie',
|
||||
"data": [],
|
||||
"radius": ['40%', '70%'],
|
||||
"avoidLabelOverlap": false,
|
||||
"label": {
|
||||
"show": true,
|
||||
"color": "#666666",
|
||||
"position": 'top',
|
||||
},
|
||||
"labelLine": {
|
||||
"show": true
|
||||
},
|
||||
},
|
||||
},
|
||||
"rose": {
|
||||
"color": color,
|
||||
"title": {
|
||||
"text": ''
|
||||
},
|
||||
"tooltip": {
|
||||
"trigger": 'item'
|
||||
},
|
||||
"legend": {
|
||||
"top": 'bottom'
|
||||
},
|
||||
"seriesTemplate": {
|
||||
"name": '',
|
||||
"type": 'pie',
|
||||
"data": [],
|
||||
"radius": "55%",
|
||||
"center": ['50%', '50%'],
|
||||
"roseType": 'area',
|
||||
},
|
||||
},
|
||||
"funnel": {
|
||||
"color": color,
|
||||
"title": {
|
||||
"text": ''
|
||||
},
|
||||
"tooltip": {
|
||||
"trigger": 'item',
|
||||
"formatter": "{b} : {c}%"
|
||||
},
|
||||
"legend": {
|
||||
"top": 'bottom'
|
||||
},
|
||||
"seriesTemplate": {
|
||||
"name": '',
|
||||
"type": 'funnel',
|
||||
"left": '10%',
|
||||
"top": 60,
|
||||
"bottom": 60,
|
||||
"width": '80%',
|
||||
"min": 0,
|
||||
"max": 100,
|
||||
"minSize": '0%',
|
||||
"maxSize": '100%',
|
||||
"sort": 'descending',
|
||||
"gap": 2,
|
||||
"label": {
|
||||
"show": true,
|
||||
"position": 'inside'
|
||||
},
|
||||
"labelLine": {
|
||||
"length": 10,
|
||||
"lineStyle": {
|
||||
"width": 1,
|
||||
"type": 'solid'
|
||||
}
|
||||
},
|
||||
"itemStyle": {
|
||||
"bordercolor": '#fff',
|
||||
"borderwidth": 1
|
||||
},
|
||||
"emphasis": {
|
||||
"label": {
|
||||
"fontSize": 20
|
||||
}
|
||||
},
|
||||
"data": [],
|
||||
},
|
||||
},
|
||||
"gauge": {
|
||||
"color": color,
|
||||
"tooltip": {
|
||||
"formatter": '{a} <br/>{b} : {c}%'
|
||||
},
|
||||
"seriesTemplate": {
|
||||
"name": '业务指标',
|
||||
"type": 'gauge',
|
||||
"detail": {"formatter": '{value}%'},
|
||||
"data": [{"value": 50, "name": '完成率'}]
|
||||
},
|
||||
},
|
||||
"candle": {
|
||||
"xAxis": {
|
||||
"data": []
|
||||
},
|
||||
"yAxis": {},
|
||||
"color": color,
|
||||
"title": {
|
||||
"text": ''
|
||||
},
|
||||
"dataZoom": [{
|
||||
"type": 'inside',
|
||||
"xAxisIndex": [0, 1],
|
||||
"start": 10,
|
||||
"end": 100
|
||||
},
|
||||
{
|
||||
"show": true,
|
||||
"xAxisIndex": [0, 1],
|
||||
"type": 'slider',
|
||||
"bottom": 10,
|
||||
"start": 10,
|
||||
"end": 100
|
||||
}
|
||||
],
|
||||
"seriesTemplate": {
|
||||
"name": '',
|
||||
"type": 'k',
|
||||
"data": [],
|
||||
},
|
||||
}
|
||||
}
|
||||
|
||||
export default cfe;
|
||||
@@ -0,0 +1,606 @@
|
||||
/*
|
||||
* uCharts®
|
||||
* 高性能跨平台图表库,支持H5、APP、小程序(微信/支付宝/百度/头条/QQ/360)、Vue、Taro等支持canvas的框架平台
|
||||
* Copyright (c) 2021 QIUN®秋云 https://www.ucharts.cn All rights reserved.
|
||||
* Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )
|
||||
* 复制使用请保留本段注释,感谢支持开源!
|
||||
*
|
||||
* uCharts®官方网站
|
||||
* https://www.uCharts.cn
|
||||
*
|
||||
* 开源地址:
|
||||
* https://gitee.com/uCharts/uCharts
|
||||
*
|
||||
* uni-app插件市场地址:
|
||||
* http://ext.dcloud.net.cn/plugin?id=271
|
||||
*
|
||||
*/
|
||||
|
||||
// 主题颜色配置:如每个图表类型需要不同主题,请在对应图表类型上更改color属性
|
||||
const color = ['#1890FF', '#91CB74', '#FAC858', '#EE6666', '#73C0DE', '#3CA272', '#FC8452', '#9A60B4', '#ea7ccc'];
|
||||
|
||||
//事件转换函数,主要用作格式化x轴为时间轴,根据需求自行修改
|
||||
const formatDateTime = (timeStamp, returnType)=>{
|
||||
var date = new Date();
|
||||
date.setTime(timeStamp * 1000);
|
||||
var y = date.getFullYear();
|
||||
var m = date.getMonth() + 1;
|
||||
m = m < 10 ? ('0' + m) : m;
|
||||
var d = date.getDate();
|
||||
d = d < 10 ? ('0' + d) : d;
|
||||
var h = date.getHours();
|
||||
h = h < 10 ? ('0' + h) : h;
|
||||
var minute = date.getMinutes();
|
||||
var second = date.getSeconds();
|
||||
minute = minute < 10 ? ('0' + minute) : minute;
|
||||
second = second < 10 ? ('0' + second) : second;
|
||||
if(returnType == 'full'){return y + '-' + m + '-' + d + ' '+ h +':' + minute + ':' + second;}
|
||||
if(returnType == 'y-m-d'){return y + '-' + m + '-' + d;}
|
||||
if(returnType == 'h:m'){return h +':' + minute;}
|
||||
if(returnType == 'h:m:s'){return h +':' + minute +':' + second;}
|
||||
return [y, m, d, h, minute, second];
|
||||
}
|
||||
|
||||
const cfu = {
|
||||
//demotype为自定义图表类型,一般不需要自定义图表类型,只需要改根节点上对应的类型即可
|
||||
"type":["pie","ring","rose","word","funnel","map","arcbar","line","column","mount","bar","area","radar","gauge","candle","mix","tline","tarea","scatter","bubble","demotype"],
|
||||
"range":["饼状图","圆环图","玫瑰图","词云图","漏斗图","地图","圆弧进度条","折线图","柱状图","山峰图","条状图","区域图","雷达图","仪表盘","K线图","混合图","时间轴折线","时间轴区域","散点图","气泡图","自定义类型"],
|
||||
//增加自定义图表类型,如果需要categories,请在这里加入您的图表类型,例如最后的"demotype"
|
||||
//自定义类型时需要注意"tline","tarea","scatter","bubble"等时间轴(矢量x轴)类图表,没有categories,不需要加入categories
|
||||
"categories":["line","column","mount","bar","area","radar","gauge","candle","mix","demotype"],
|
||||
//instance为实例变量承载属性,不要删除
|
||||
"instance":{},
|
||||
//option为opts及eopts承载属性,不要删除
|
||||
"option":{},
|
||||
//下面是自定义format配置,因除H5端外的其他端无法通过props传递函数,只能通过此属性对应下标的方式来替换
|
||||
"formatter":{
|
||||
"yAxisDemo1":function(val, index, opts){return val+'元'},
|
||||
"yAxisDemo2":function(val, index, opts){return val.toFixed(2)},
|
||||
"xAxisDemo1":function(val, index, opts){return val+'年';},
|
||||
"xAxisDemo2":function(val, index, opts){return formatDateTime(val,'h:m')},
|
||||
"seriesDemo1":function(val, index, series, opts){return val+'元'},
|
||||
"tooltipDemo1":function(item, category, index, opts){
|
||||
if(index==0){
|
||||
return '随便用'+item.data+'年'
|
||||
}else{
|
||||
return '其他我没改'+item.data+'天'
|
||||
}
|
||||
},
|
||||
"pieDemo":function(val, index, series, opts){
|
||||
if(index !== undefined){
|
||||
return series[index].name+':'+series[index].data+'元'
|
||||
}
|
||||
},
|
||||
},
|
||||
//这里演示了自定义您的图表类型的option,可以随意命名,之后在组件上 type="demotype" 后,组件会调用这个花括号里的option,如果组件上还存在opts参数,会将demotype与opts中option合并后渲染图表。
|
||||
"demotype":{
|
||||
//我这里把曲线图当做了自定义图表类型,您可以根据需要随意指定类型或配置
|
||||
"type": "line",
|
||||
"color": color,
|
||||
"padding": [15,10,0,15],
|
||||
"xAxis": {
|
||||
"disableGrid": true,
|
||||
},
|
||||
"yAxis": {
|
||||
"gridType": "dash",
|
||||
"dashLength": 2,
|
||||
},
|
||||
"legend": {
|
||||
},
|
||||
"extra": {
|
||||
"line": {
|
||||
"type": "curve",
|
||||
"width": 2
|
||||
},
|
||||
}
|
||||
},
|
||||
//下面是自定义配置,请添加项目所需的通用配置
|
||||
"pie":{
|
||||
"type": "pie",
|
||||
"color": color,
|
||||
"padding": [5,5,5,5],
|
||||
"extra": {
|
||||
"pie": {
|
||||
"activeOpacity": 0.5,
|
||||
"activeRadius": 10,
|
||||
"offsetAngle": 0,
|
||||
"labelWidth": 15,
|
||||
"border": true,
|
||||
"borderWidth": 3,
|
||||
"borderColor": "#FFFFFF"
|
||||
},
|
||||
}
|
||||
},
|
||||
"ring":{
|
||||
"type": "ring",
|
||||
"color": color,
|
||||
"padding": [5,5,5,5],
|
||||
"rotate": false,
|
||||
"dataLabel": true,
|
||||
"legend": {
|
||||
"show": true,
|
||||
"position": "right",
|
||||
"lineHeight": 25,
|
||||
},
|
||||
"title": {
|
||||
"name": "收益率",
|
||||
"fontSize": 15,
|
||||
"color": "#666666"
|
||||
},
|
||||
"subtitle": {
|
||||
"name": "70%",
|
||||
"fontSize": 25,
|
||||
"color": "#7cb5ec"
|
||||
},
|
||||
"extra": {
|
||||
"ring": {
|
||||
"ringWidth":30,
|
||||
"activeOpacity": 0.5,
|
||||
"activeRadius": 10,
|
||||
"offsetAngle": 0,
|
||||
"labelWidth": 15,
|
||||
"border": true,
|
||||
"borderWidth": 3,
|
||||
"borderColor": "#FFFFFF"
|
||||
},
|
||||
},
|
||||
},
|
||||
"rose":{
|
||||
"type": "rose",
|
||||
"color": color,
|
||||
"padding": [5,5,5,5],
|
||||
"legend": {
|
||||
"show": true,
|
||||
"position": "left",
|
||||
"lineHeight": 25,
|
||||
},
|
||||
"extra": {
|
||||
"rose": {
|
||||
"type": "area",
|
||||
"minRadius": 50,
|
||||
"activeOpacity": 0.5,
|
||||
"activeRadius": 10,
|
||||
"offsetAngle": 0,
|
||||
"labelWidth": 15,
|
||||
"border": false,
|
||||
"borderWidth": 2,
|
||||
"borderColor": "#FFFFFF"
|
||||
},
|
||||
}
|
||||
},
|
||||
"word":{
|
||||
"type": "word",
|
||||
"color": color,
|
||||
"extra": {
|
||||
"word": {
|
||||
"type": "normal",
|
||||
"autoColors": false
|
||||
}
|
||||
}
|
||||
},
|
||||
"funnel":{
|
||||
"type": "funnel",
|
||||
"color": color,
|
||||
"padding": [15,15,0,15],
|
||||
"extra": {
|
||||
"funnel": {
|
||||
"activeOpacity": 0.3,
|
||||
"activeWidth": 10,
|
||||
"border": true,
|
||||
"borderWidth": 2,
|
||||
"borderColor": "#FFFFFF",
|
||||
"fillOpacity": 1,
|
||||
"labelAlign": "right"
|
||||
},
|
||||
}
|
||||
},
|
||||
"map":{
|
||||
"type": "map",
|
||||
"color": color,
|
||||
"padding": [0,0,0,0],
|
||||
"dataLabel": true,
|
||||
"extra": {
|
||||
"map": {
|
||||
"border": true,
|
||||
"borderWidth": 1,
|
||||
"borderColor": "#666666",
|
||||
"fillOpacity": 0.6,
|
||||
"activeBorderColor": "#F04864",
|
||||
"activeFillColor": "#FACC14",
|
||||
"activeFillOpacity": 1
|
||||
},
|
||||
}
|
||||
},
|
||||
"arcbar":{
|
||||
"type": "arcbar",
|
||||
"color": color,
|
||||
"title": {
|
||||
"name": "百分比",
|
||||
"fontSize": 25,
|
||||
"color": "#00FF00"
|
||||
},
|
||||
"subtitle": {
|
||||
"name": "默认标题",
|
||||
"fontSize": 15,
|
||||
"color": "#666666"
|
||||
},
|
||||
"extra": {
|
||||
"arcbar": {
|
||||
"type": "default",
|
||||
"width": 12,
|
||||
"backgroundColor": "#E9E9E9",
|
||||
"startAngle": 0.75,
|
||||
"endAngle": 0.25,
|
||||
"gap": 2
|
||||
}
|
||||
}
|
||||
},
|
||||
"line":{
|
||||
"type": "line",
|
||||
"color": color,
|
||||
"padding": [15,10,0,15],
|
||||
"xAxis": {
|
||||
"disableGrid": true,
|
||||
},
|
||||
"yAxis": {
|
||||
"gridType": "dash",
|
||||
"dashLength": 2,
|
||||
},
|
||||
"legend": {
|
||||
},
|
||||
"extra": {
|
||||
"line": {
|
||||
"type": "straight",
|
||||
"width": 2,
|
||||
"activeType": "hollow"
|
||||
},
|
||||
}
|
||||
},
|
||||
"tline":{
|
||||
"type": "line",
|
||||
"color": color,
|
||||
"padding": [15,10,0,15],
|
||||
"xAxis": {
|
||||
"disableGrid": false,
|
||||
"boundaryGap":"justify",
|
||||
},
|
||||
"yAxis": {
|
||||
"gridType": "dash",
|
||||
"dashLength": 2,
|
||||
"data":[
|
||||
{
|
||||
"min":0,
|
||||
"max":80
|
||||
}
|
||||
]
|
||||
},
|
||||
"legend": {
|
||||
},
|
||||
"extra": {
|
||||
"line": {
|
||||
"type": "curve",
|
||||
"width": 2,
|
||||
"activeType": "hollow"
|
||||
},
|
||||
}
|
||||
},
|
||||
"tarea":{
|
||||
"type": "area",
|
||||
"color": color,
|
||||
"padding": [15,10,0,15],
|
||||
"xAxis": {
|
||||
"disableGrid": true,
|
||||
"boundaryGap":"justify",
|
||||
},
|
||||
"yAxis": {
|
||||
"gridType": "dash",
|
||||
"dashLength": 2,
|
||||
"data":[
|
||||
{
|
||||
"min":0,
|
||||
"max":80
|
||||
}
|
||||
]
|
||||
},
|
||||
"legend": {
|
||||
},
|
||||
"extra": {
|
||||
"area": {
|
||||
"type": "curve",
|
||||
"opacity": 0.2,
|
||||
"addLine": true,
|
||||
"width": 2,
|
||||
"gradient": true,
|
||||
"activeType": "hollow"
|
||||
},
|
||||
}
|
||||
},
|
||||
"column":{
|
||||
"type": "column",
|
||||
"color": color,
|
||||
"padding": [15,15,0,5],
|
||||
"xAxis": {
|
||||
"disableGrid": true,
|
||||
},
|
||||
"yAxis": {
|
||||
"data":[{"min":0}]
|
||||
},
|
||||
"legend": {
|
||||
},
|
||||
"extra": {
|
||||
"column": {
|
||||
"type": "group",
|
||||
"width": 30,
|
||||
"activeBgColor": "#000000",
|
||||
"activeBgOpacity": 0.08
|
||||
},
|
||||
}
|
||||
},
|
||||
"mount":{
|
||||
"type": "mount",
|
||||
"color": color,
|
||||
"padding": [15,15,0,5],
|
||||
"xAxis": {
|
||||
"disableGrid": true,
|
||||
},
|
||||
"yAxis": {
|
||||
"data":[{"min":0}]
|
||||
},
|
||||
"legend": {
|
||||
},
|
||||
"extra": {
|
||||
"mount": {
|
||||
"type": "mount",
|
||||
"widthRatio": 1.5,
|
||||
},
|
||||
}
|
||||
},
|
||||
"bar":{
|
||||
"type": "bar",
|
||||
"color": color,
|
||||
"padding": [15,30,0,5],
|
||||
"xAxis": {
|
||||
"boundaryGap":"justify",
|
||||
"disableGrid":false,
|
||||
"min":0,
|
||||
"axisLine":false
|
||||
},
|
||||
"yAxis": {
|
||||
},
|
||||
"legend": {
|
||||
},
|
||||
"extra": {
|
||||
"bar": {
|
||||
"type": "group",
|
||||
"width": 30,
|
||||
"meterBorde": 1,
|
||||
"meterFillColor": "#FFFFFF",
|
||||
"activeBgColor": "#000000",
|
||||
"activeBgOpacity": 0.08
|
||||
},
|
||||
}
|
||||
},
|
||||
"area":{
|
||||
"type": "area",
|
||||
"color": color,
|
||||
"padding": [15,15,0,15],
|
||||
"xAxis": {
|
||||
"disableGrid": true,
|
||||
},
|
||||
"yAxis": {
|
||||
"gridType": "dash",
|
||||
"dashLength": 2,
|
||||
},
|
||||
"legend": {
|
||||
},
|
||||
"extra": {
|
||||
"area": {
|
||||
"type": "straight",
|
||||
"opacity": 0.2,
|
||||
"addLine": true,
|
||||
"width": 2,
|
||||
"gradient": false,
|
||||
"activeType": "hollow"
|
||||
},
|
||||
}
|
||||
},
|
||||
"radar":{
|
||||
"type": "radar",
|
||||
"color": color,
|
||||
"padding": [5,5,5,5],
|
||||
"dataLabel": false,
|
||||
"legend": {
|
||||
"show": true,
|
||||
"position": "right",
|
||||
"lineHeight": 25,
|
||||
},
|
||||
"extra": {
|
||||
"radar": {
|
||||
"gridType": "radar",
|
||||
"gridColor": "#CCCCCC",
|
||||
"gridCount": 3,
|
||||
"opacity": 0.2,
|
||||
"max": 200,
|
||||
"labelShow": true
|
||||
},
|
||||
}
|
||||
},
|
||||
"gauge":{
|
||||
"type": "gauge",
|
||||
"color": color,
|
||||
"title": {
|
||||
"name": "66Km/H",
|
||||
"fontSize": 25,
|
||||
"color": "#2fc25b",
|
||||
"offsetY": 50
|
||||
},
|
||||
"subtitle": {
|
||||
"name": "实时速度",
|
||||
"fontSize": 15,
|
||||
"color": "#1890ff",
|
||||
"offsetY": -50
|
||||
},
|
||||
"extra": {
|
||||
"gauge": {
|
||||
"type": "default",
|
||||
"width": 30,
|
||||
"labelColor": "#666666",
|
||||
"startAngle": 0.75,
|
||||
"endAngle": 0.25,
|
||||
"startNumber": 0,
|
||||
"endNumber": 100,
|
||||
"labelFormat": "",
|
||||
"splitLine": {
|
||||
"fixRadius": 0,
|
||||
"splitNumber": 10,
|
||||
"width": 30,
|
||||
"color": "#FFFFFF",
|
||||
"childNumber": 5,
|
||||
"childWidth": 12
|
||||
},
|
||||
"pointer": {
|
||||
"width": 24,
|
||||
"color": "auto"
|
||||
}
|
||||
}
|
||||
}
|
||||
},
|
||||
"candle":{
|
||||
"type": "candle",
|
||||
"color": color,
|
||||
"padding": [15,15,0,15],
|
||||
"enableScroll": true,
|
||||
"enableMarkLine": true,
|
||||
"dataLabel": false,
|
||||
"xAxis": {
|
||||
"labelCount": 4,
|
||||
"itemCount": 40,
|
||||
"disableGrid": true,
|
||||
"gridColor": "#CCCCCC",
|
||||
"gridType": "solid",
|
||||
"dashLength": 4,
|
||||
"scrollShow": true,
|
||||
"scrollAlign": "left",
|
||||
"scrollColor": "#A6A6A6",
|
||||
"scrollBackgroundColor": "#EFEBEF"
|
||||
},
|
||||
"yAxis": {
|
||||
},
|
||||
"legend": {
|
||||
},
|
||||
"extra": {
|
||||
"candle": {
|
||||
"color": {
|
||||
"upLine": "#f04864",
|
||||
"upFill": "#f04864",
|
||||
"downLine": "#2fc25b",
|
||||
"downFill": "#2fc25b"
|
||||
},
|
||||
"average": {
|
||||
"show": true,
|
||||
"name": ["MA5","MA10","MA30"],
|
||||
"day": [5,10,20],
|
||||
"color": ["#1890ff","#2fc25b","#facc14"]
|
||||
}
|
||||
},
|
||||
"markLine": {
|
||||
"type": "dash",
|
||||
"dashLength": 5,
|
||||
"data": [
|
||||
{
|
||||
"value": 2150,
|
||||
"lineColor": "#f04864",
|
||||
"showLabel": true
|
||||
},
|
||||
{
|
||||
"value": 2350,
|
||||
"lineColor": "#f04864",
|
||||
"showLabel": true
|
||||
}
|
||||
]
|
||||
}
|
||||
}
|
||||
},
|
||||
"mix":{
|
||||
"type": "mix",
|
||||
"color": color,
|
||||
"padding": [15,15,0,15],
|
||||
"xAxis": {
|
||||
"disableGrid": true,
|
||||
},
|
||||
"yAxis": {
|
||||
"disabled": false,
|
||||
"disableGrid": false,
|
||||
"splitNumber": 5,
|
||||
"gridType": "dash",
|
||||
"dashLength": 4,
|
||||
"gridColor": "#CCCCCC",
|
||||
"padding": 10,
|
||||
"showTitle": true,
|
||||
"data": []
|
||||
},
|
||||
"legend": {
|
||||
},
|
||||
"extra": {
|
||||
"mix": {
|
||||
"column": {
|
||||
"width": 20
|
||||
}
|
||||
},
|
||||
}
|
||||
},
|
||||
"scatter":{
|
||||
"type": "scatter",
|
||||
"color":color,
|
||||
"padding":[15,15,0,15],
|
||||
"dataLabel":false,
|
||||
"xAxis": {
|
||||
"disableGrid": false,
|
||||
"gridType":"dash",
|
||||
"splitNumber":5,
|
||||
"boundaryGap":"justify",
|
||||
"min":0
|
||||
},
|
||||
"yAxis": {
|
||||
"disableGrid": false,
|
||||
"gridType":"dash",
|
||||
},
|
||||
"legend": {
|
||||
},
|
||||
"extra": {
|
||||
"scatter": {
|
||||
},
|
||||
}
|
||||
},
|
||||
"bubble":{
|
||||
"type": "bubble",
|
||||
"color":color,
|
||||
"padding":[15,15,0,15],
|
||||
"xAxis": {
|
||||
"disableGrid": false,
|
||||
"gridType":"dash",
|
||||
"splitNumber":5,
|
||||
"boundaryGap":"justify",
|
||||
"min":0,
|
||||
"max":250
|
||||
},
|
||||
"yAxis": {
|
||||
"disableGrid": false,
|
||||
"gridType":"dash",
|
||||
"data":[{
|
||||
"min":0,
|
||||
"max":150
|
||||
}]
|
||||
},
|
||||
"legend": {
|
||||
},
|
||||
"extra": {
|
||||
"bubble": {
|
||||
"border":2,
|
||||
"opacity": 0.5,
|
||||
},
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
export default cfu;
|
||||
@@ -0,0 +1,5 @@
|
||||
# uCharts JSSDK说明
|
||||
1、如不使用uCharts组件,可直接引用u-charts.js,打包编译后会`自动压缩`,压缩后体积约为`120kb`。
|
||||
2、如果120kb的体积仍需压缩,请手到uCharts官网通过在线定制选择您需要的图表。
|
||||
3、config-ucharts.js为uCharts组件的用户配置文件,升级前请`自行备份config-ucharts.js`文件,以免被强制覆盖。
|
||||
4、config-echarts.js为ECharts组件的用户配置文件,升级前请`自行备份config-echarts.js`文件,以免被强制覆盖。
|
||||
File diff suppressed because it is too large
Load Diff
18
apps/hand-factory/components/qiun-data-charts/js_sdk/u-charts/u-charts.min.js
vendored
Normal file
18
apps/hand-factory/components/qiun-data-charts/js_sdk/u-charts/u-charts.min.js
vendored
Normal file
File diff suppressed because one or more lines are too long
201
apps/hand-factory/components/qiun-data-charts/license.md
Normal file
201
apps/hand-factory/components/qiun-data-charts/license.md
Normal file
@@ -0,0 +1,201 @@
|
||||
Apache License
|
||||
Version 2.0, January 2004
|
||||
http://www.apache.org/licenses/
|
||||
|
||||
TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
|
||||
|
||||
1. Definitions.
|
||||
|
||||
"License" shall mean the terms and conditions for use, reproduction,
|
||||
and distribution as defined by Sections 1 through 9 of this document.
|
||||
|
||||
"Licensor" shall mean the copyright owner or entity authorized by
|
||||
the copyright owner that is granting the License.
|
||||
|
||||
"Legal Entity" shall mean the union of the acting entity and all
|
||||
other entities that control, are controlled by, or are under common
|
||||
control with that entity. For the purposes of this definition,
|
||||
"control" means (i) the power, direct or indirect, to cause the
|
||||
direction or management of such entity, whether by contract or
|
||||
otherwise, or (ii) ownership of fifty percent (50%) or more of the
|
||||
outstanding shares, or (iii) beneficial ownership of such entity.
|
||||
|
||||
"You" (or "Your") shall mean an individual or Legal Entity
|
||||
exercising permissions granted by this License.
|
||||
|
||||
"Source" form shall mean the preferred form for making modifications,
|
||||
including but not limited to software source code, documentation
|
||||
source, and configuration files.
|
||||
|
||||
"Object" form shall mean any form resulting from mechanical
|
||||
transformation or translation of a Source form, including but
|
||||
not limited to compiled object code, generated documentation,
|
||||
and conversions to other media types.
|
||||
|
||||
"Work" shall mean the work of authorship, whether in Source or
|
||||
Object form, made available under the License, as indicated by a
|
||||
copyright notice that is included in or attached to the work
|
||||
(an example is provided in the Appendix below).
|
||||
|
||||
"Derivative Works" shall mean any work, whether in Source or Object
|
||||
form, that is based on (or derived from) the Work and for which the
|
||||
editorial revisions, annotations, elaborations, or other modifications
|
||||
represent, as a whole, an original work of authorship. For the purposes
|
||||
of this License, Derivative Works shall not include works that remain
|
||||
separable from, or merely link (or bind by name) to the interfaces of,
|
||||
the Work and Derivative Works thereof.
|
||||
|
||||
"Contribution" shall mean any work of authorship, including
|
||||
the original version of the Work and any modifications or additions
|
||||
to that Work or Derivative Works thereof, that is intentionally
|
||||
submitted to Licensor for inclusion in the Work by the copyright owner
|
||||
or by an individual or Legal Entity authorized to submit on behalf of
|
||||
the copyright owner. For the purposes of this definition, "submitted"
|
||||
means any form of electronic, verbal, or written communication sent
|
||||
to the Licensor or its representatives, including but not limited to
|
||||
communication on electronic mailing lists, source code control systems,
|
||||
and issue tracking systems that are managed by, or on behalf of, the
|
||||
Licensor for the purpose of discussing and improving the Work, but
|
||||
excluding communication that is conspicuously marked or otherwise
|
||||
designated in writing by the copyright owner as "Not a Contribution."
|
||||
|
||||
"Contributor" shall mean Licensor and any individual or Legal Entity
|
||||
on behalf of whom a Contribution has been received by Licensor and
|
||||
subsequently incorporated within the Work.
|
||||
|
||||
2. Grant of Copyright License. Subject to the terms and conditions of
|
||||
this License, each Contributor hereby grants to You a perpetual,
|
||||
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
||||
copyright license to reproduce, prepare Derivative Works of,
|
||||
publicly display, publicly perform, sublicense, and distribute the
|
||||
Work and such Derivative Works in Source or Object form.
|
||||
|
||||
3. Grant of Patent License. Subject to the terms and conditions of
|
||||
this License, each Contributor hereby grants to You a perpetual,
|
||||
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
||||
(except as stated in this section) patent license to make, have made,
|
||||
use, offer to sell, sell, import, and otherwise transfer the Work,
|
||||
where such license applies only to those patent claims licensable
|
||||
by such Contributor that are necessarily infringed by their
|
||||
Contribution(s) alone or by combination of their Contribution(s)
|
||||
with the Work to which such Contribution(s) was submitted. If You
|
||||
institute patent litigation against any entity (including a
|
||||
cross-claim or counterclaim in a lawsuit) alleging that the Work
|
||||
or a Contribution incorporated within the Work constitutes direct
|
||||
or contributory patent infringement, then any patent licenses
|
||||
granted to You under this License for that Work shall terminate
|
||||
as of the date such litigation is filed.
|
||||
|
||||
4. Redistribution. You may reproduce and distribute copies of the
|
||||
Work or Derivative Works thereof in any medium, with or without
|
||||
modifications, and in Source or Object form, provided that You
|
||||
meet the following conditions:
|
||||
|
||||
(a) You must give any other recipients of the Work or
|
||||
Derivative Works a copy of this License; and
|
||||
|
||||
(b) You must cause any modified files to carry prominent notices
|
||||
stating that You changed the files; and
|
||||
|
||||
(c) You must retain, in the Source form of any Derivative Works
|
||||
that You distribute, all copyright, patent, trademark, and
|
||||
attribution notices from the Source form of the Work,
|
||||
excluding those notices that do not pertain to any part of
|
||||
the Derivative Works; and
|
||||
|
||||
(d) If the Work includes a "NOTICE" text file as part of its
|
||||
distribution, then any Derivative Works that You distribute must
|
||||
include a readable copy of the attribution notices contained
|
||||
within such NOTICE file, excluding those notices that do not
|
||||
pertain to any part of the Derivative Works, in at least one
|
||||
of the following places: within a NOTICE text file distributed
|
||||
as part of the Derivative Works; within the Source form or
|
||||
documentation, if provided along with the Derivative Works; or,
|
||||
within a display generated by the Derivative Works, if and
|
||||
wherever such third-party notices normally appear. The contents
|
||||
of the NOTICE file are for informational purposes only and
|
||||
do not modify the License. You may add Your own attribution
|
||||
notices within Derivative Works that You distribute, alongside
|
||||
or as an addendum to the NOTICE text from the Work, provided
|
||||
that such additional attribution notices cannot be construed
|
||||
as modifying the License.
|
||||
|
||||
You may add Your own copyright statement to Your modifications and
|
||||
may provide additional or different license terms and conditions
|
||||
for use, reproduction, or distribution of Your modifications, or
|
||||
for any such Derivative Works as a whole, provided Your use,
|
||||
reproduction, and distribution of the Work otherwise complies with
|
||||
the conditions stated in this License.
|
||||
|
||||
5. Submission of Contributions. Unless You explicitly state otherwise,
|
||||
any Contribution intentionally submitted for inclusion in the Work
|
||||
by You to the Licensor shall be under the terms and conditions of
|
||||
this License, without any additional terms or conditions.
|
||||
Notwithstanding the above, nothing herein shall supersede or modify
|
||||
the terms of any separate license agreement you may have executed
|
||||
with Licensor regarding such Contributions.
|
||||
|
||||
6. Trademarks. This License does not grant permission to use the trade
|
||||
names, trademarks, service marks, or product names of the Licensor,
|
||||
except as required for reasonable and customary use in describing the
|
||||
origin of the Work and reproducing the content of the NOTICE file.
|
||||
|
||||
7. Disclaimer of Warranty. Unless required by applicable law or
|
||||
agreed to in writing, Licensor provides the Work (and each
|
||||
Contributor provides its Contributions) on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
||||
implied, including, without limitation, any warranties or conditions
|
||||
of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
|
||||
PARTICULAR PURPOSE. You are solely responsible for determining the
|
||||
appropriateness of using or redistributing the Work and assume any
|
||||
risks associated with Your exercise of permissions under this License.
|
||||
|
||||
8. Limitation of Liability. In no event and under no legal theory,
|
||||
whether in tort (including negligence), contract, or otherwise,
|
||||
unless required by applicable law (such as deliberate and grossly
|
||||
negligent acts) or agreed to in writing, shall any Contributor be
|
||||
liable to You for damages, including any direct, indirect, special,
|
||||
incidental, or consequential damages of any character arising as a
|
||||
result of this License or out of the use or inability to use the
|
||||
Work (including but not limited to damages for loss of goodwill,
|
||||
work stoppage, computer failure or malfunction, or any and all
|
||||
other commercial damages or losses), even if such Contributor
|
||||
has been advised of the possibility of such damages.
|
||||
|
||||
9. Accepting Warranty or Additional Liability. While redistributing
|
||||
the Work or Derivative Works thereof, You may choose to offer,
|
||||
and charge a fee for, acceptance of support, warranty, indemnity,
|
||||
or other liability obligations and/or rights consistent with this
|
||||
License. However, in accepting such obligations, You may act only
|
||||
on Your own behalf and on Your sole responsibility, not on behalf
|
||||
of any other Contributor, and only if You agree to indemnify,
|
||||
defend, and hold each Contributor harmless for any liability
|
||||
incurred by, or claims asserted against, such Contributor by reason
|
||||
of your accepting any such warranty or additional liability.
|
||||
|
||||
END OF TERMS AND CONDITIONS
|
||||
|
||||
APPENDIX: How to apply the Apache License to your work.
|
||||
|
||||
To apply the Apache License to your work, attach the following
|
||||
boilerplate notice, with the fields enclosed by brackets "[]"
|
||||
replaced with your own identifying information. (Don't include
|
||||
the brackets!) The text should be enclosed in the appropriate
|
||||
comment syntax for the file format. We also recommend that a
|
||||
file or class name and description of purpose be included on the
|
||||
same "printed page" as the copyright notice for easier
|
||||
identification within third-party archives.
|
||||
|
||||
Copyright [yyyy] [name of copyright owner]
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
80
apps/hand-factory/components/qiun-data-charts/package.json
Normal file
80
apps/hand-factory/components/qiun-data-charts/package.json
Normal file
@@ -0,0 +1,80 @@
|
||||
{
|
||||
"id": "qiun-data-charts",
|
||||
"displayName": "秋云 ucharts echarts 高性能跨全端图表组件",
|
||||
"version": "2.5.0-20230101",
|
||||
"description": "uCharts 新增正负柱状图!支持H5及APP用 ucharts echarts 渲染图表,uniapp可视化首选组件",
|
||||
"keywords": [
|
||||
"ucharts",
|
||||
"echarts",
|
||||
"f2",
|
||||
"图表",
|
||||
"可视化"
|
||||
],
|
||||
"repository": "https://gitee.com/uCharts/uCharts",
|
||||
"engines": {
|
||||
},
|
||||
"dcloudext": {
|
||||
"sale": {
|
||||
"regular": {
|
||||
"price": "0.00"
|
||||
},
|
||||
"sourcecode": {
|
||||
"price": "0.00"
|
||||
}
|
||||
},
|
||||
"contact": {
|
||||
"qq": "474119"
|
||||
},
|
||||
"declaration": {
|
||||
"ads": "无",
|
||||
"data": "插件不采集任何数据",
|
||||
"permissions": "无"
|
||||
},
|
||||
"npmurl": "https://www.npmjs.com/~qiun",
|
||||
"type": "component-vue"
|
||||
},
|
||||
"uni_modules": {
|
||||
"dependencies": [],
|
||||
"encrypt": [],
|
||||
"platforms": {
|
||||
"cloud": {
|
||||
"tcb": "y",
|
||||
"aliyun": "y"
|
||||
},
|
||||
"client": {
|
||||
"App": {
|
||||
"app-vue": "y",
|
||||
"app-nvue": "y"
|
||||
},
|
||||
"H5-mobile": {
|
||||
"Safari": "y",
|
||||
"Android Browser": "y",
|
||||
"微信浏览器(Android)": "y",
|
||||
"QQ浏览器(Android)": "y"
|
||||
},
|
||||
"H5-pc": {
|
||||
"Chrome": "y",
|
||||
"IE": "y",
|
||||
"Edge": "y",
|
||||
"Firefox": "y",
|
||||
"Safari": "y"
|
||||
},
|
||||
"小程序": {
|
||||
"微信": "y",
|
||||
"阿里": "y",
|
||||
"百度": "y",
|
||||
"字节跳动": "y",
|
||||
"QQ": "y"
|
||||
},
|
||||
"快应用": {
|
||||
"华为": "y",
|
||||
"联盟": "y"
|
||||
},
|
||||
"Vue": {
|
||||
"vue2": "y",
|
||||
"vue3": "y"
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
84
apps/hand-factory/components/qiun-data-charts/readme.md
Normal file
84
apps/hand-factory/components/qiun-data-charts/readme.md
Normal file
@@ -0,0 +1,84 @@
|
||||

|
||||
|
||||
|
||||
[](https://gitee.com/uCharts/uCharts/stargazers)
|
||||
[](https://gitee.com/uCharts/uCharts/members)
|
||||
[](https://www.apache.org/licenses/LICENSE-2.0.html)
|
||||
[](https://www.npmjs.com/~qiun)
|
||||
|
||||
|
||||
## uCharts简介
|
||||
|
||||
`uCharts`是一款基于`canvas API`开发的适用于所有前端应用的图表库,开发者编写一套代码,可运行到 Web、iOS、Android(基于 uni-app / taro )、以及各种小程序(微信/支付宝/百度/头条/飞书/QQ/快手/钉钉/淘宝)、快应用等更多支持 canvas API 的平台。
|
||||
|
||||
## 官方网站
|
||||
|
||||
## [https://www.ucharts.cn](https://www.ucharts.cn)
|
||||
|
||||
## 快速体验
|
||||
|
||||
一套代码编到多个平台,依次扫描二维码,亲自体验uCharts图表跨平台效果!其他平台请自行编译。
|
||||
|
||||

|
||||
|
||||

|
||||
|
||||
## 致开发者
|
||||
|
||||
感谢各位开发者`五年`来对秋云及uCharts的支持,uCharts的进步离不开各位开发者的鼓励与贡献。为更好的帮助各位开发者使用图表工具,我们推出了新版官网,增加了在线定制、问答社区、在线配置等一些增值服务,为确保您能更好的应用图表组件,建议您先`仔细阅读官网指南`以及`常见问题`,而不是下载下来`直接使用`。如仍然不能解决,请到`官网社区`或开通会员后加入`专属VIP会员群`提问将会很快得到回答。
|
||||
|
||||
## 视频教程
|
||||
|
||||
## [uCharts新手入门教程](https://www.bilibili.com/video/BV1qA411Q7se/?share_source=copy_web&vd_source=42a1242f9aaade6427736af69eb2e1d9)
|
||||
|
||||
|
||||
## 社群支持
|
||||
|
||||
uCharts官方拥有5个2000人的QQ群及专属VIP会员群支持,庞大的用户量证明我们一直在努力,请各位放心使用!uCharts的开源图表组件的开发,团队付出了大量的时间与精力,经过四来的考验,不会有比较明显的bug,请各位放心使用。如果您有更好的想法,可以在`码云提交Pull Requests`以帮助更多开发者完成需求,再次感谢各位对uCharts的鼓励与支持!
|
||||
|
||||
#### 官方交流群
|
||||
- 交流群1:371774600(已满)
|
||||
- 交流群2:619841586(已满)
|
||||
- 交流群3:955340127(已满)
|
||||
- 交流群4:641669795(已满)
|
||||
- 交流群5:236294809(只能扫码加入)
|
||||
|
||||

|
||||
|
||||
- 口令`uniapp`
|
||||
|
||||
#### 专属VIP会员群
|
||||
- 开通会员后详见【账号详情】页面中顶部的滚动通知
|
||||
- 口令`您的用户ID`
|
||||
|
||||
## 版权信息
|
||||
|
||||
uCharts始终坚持开源,遵循 [Apache Licence 2.0](https://www.apache.org/licenses/LICENSE-2.0.html) 开源协议,意味着您无需支付任何费用,即可将uCharts应用到您的产品中。
|
||||
|
||||
注意:这并不意味着您可以将uCharts应用到非法的领域,比如涉及赌博,暴力等方面。如因此产生纠纷或法律问题,uCharts相关方及秋云科技不承担任何责任。
|
||||
|
||||
## 合作伙伴
|
||||
|
||||
[](https://www.diygw.com/)
|
||||
[](https://gitee.com/howcode/has-chat)
|
||||
[](https://www.uviewui.com/)
|
||||
[](https://ext.dcloud.net.cn/plugin?id=7088)
|
||||
[](https://ext.dcloud.net.cn/publisher?id=202)
|
||||
[](https://www.firstui.cn/)
|
||||
[](https://ext.dcloud.net.cn/plugin?id=5169)
|
||||
[](https://www.graceui.com/)
|
||||
|
||||
|
||||
## 更新记录
|
||||
|
||||
详见官网指南中说明,[点击此处查看](https://www.ucharts.cn/v2/#/guide/index?id=100)
|
||||
|
||||
|
||||
## 相关链接
|
||||
- [uCharts官网](https://www.ucharts.cn)
|
||||
- [DCloud插件市场地址](https://ext.dcloud.net.cn/plugin?id=271)
|
||||
- [uCharts码云开源托管地址](https://gitee.com/uCharts/uCharts) [](https://gitee.com/uCharts/uCharts/stargazers)
|
||||
- [uCharts npm开源地址](https://www.ucharts.cn)
|
||||
- [ECharts官网](https://echarts.apache.org/zh/index.html)
|
||||
- [ECharts配置手册](https://echarts.apache.org/zh/option.html)
|
||||
- [图表组件在项目中的应用 ReportPlus数据报表](https://www.ucharts.cn/v2/#/layout/info?id=1)
|
||||
23
apps/hand-factory/components/qiun-data-charts/static/app-plus/echarts.min.js
vendored
Normal file
23
apps/hand-factory/components/qiun-data-charts/static/app-plus/echarts.min.js
vendored
Normal file
File diff suppressed because one or more lines are too long
23
apps/hand-factory/components/qiun-data-charts/static/h5/echarts.min.js
vendored
Normal file
23
apps/hand-factory/components/qiun-data-charts/static/h5/echarts.min.js
vendored
Normal file
File diff suppressed because one or more lines are too long
@@ -0,0 +1,135 @@
|
||||
<template>
|
||||
<view class="result-card" v-if="scanResult && codeStatus !== undefined">
|
||||
<!-- 头部:标题+时间 -->
|
||||
<view class="result-header">
|
||||
<text class="result-title">扫码信息</text>
|
||||
<text class="result-time">{{ currentTime }}</text>
|
||||
</view>
|
||||
|
||||
<!-- 主体:根据配置循环渲染字段,无v-if -->
|
||||
<view class="result-body">
|
||||
<view
|
||||
class="info-item"
|
||||
v-for="(column, index) in displayColumns"
|
||||
:key="index"
|
||||
v-if="column.showCondition(codeStatus, scanResult)"
|
||||
>
|
||||
<text class="info-label">{{ column.label }}:</text>
|
||||
<text class="info-value">
|
||||
{{ column.formatter ? column.formatter(scanResult[column.key], codeStatus) : scanResult[column.key] || '无' }}
|
||||
</text>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
import { formatIoType, formatItemType } from '@/utils/wms';
|
||||
import { CODE_STATUS } from '@/constants/wms';
|
||||
|
||||
export default {
|
||||
name: 'ScanResultCard',
|
||||
props: {
|
||||
scanResult: {
|
||||
type: Object,
|
||||
default: () => null,
|
||||
required: true
|
||||
},
|
||||
currentTime: {
|
||||
type: String,
|
||||
default: '',
|
||||
required: true
|
||||
},
|
||||
codeStatus: {
|
||||
type: Number,
|
||||
default: CODE_STATUS.UNUSED, // 默认未使用
|
||||
required: true
|
||||
}
|
||||
},
|
||||
computed: {
|
||||
// 字段显示配置:集中定义“显示哪些字段、怎么显示”
|
||||
displayColumns() {
|
||||
return [
|
||||
// 操作类型:仅状态0/1显示
|
||||
{
|
||||
label: '操作类型',
|
||||
key: 'ioType', // scanResult中的键
|
||||
formatter: formatIoType, // 调用工具函数格式化
|
||||
showCondition: (status) => status !== CODE_STATUS.OUT_STOCK // 状态2(已出库)不显示
|
||||
},
|
||||
// 物品类型:所有状态显示
|
||||
{
|
||||
label: '物品类型',
|
||||
key: 'itemType',
|
||||
formatter: formatItemType,
|
||||
showCondition: () => true // 始终显示
|
||||
},
|
||||
// 数量:所有状态显示(注意:原组件用count,父组件用quantity,这里统一为quantity)
|
||||
{
|
||||
label: '数量',
|
||||
key: 'quantity',
|
||||
formatter: (val) => val || 0,
|
||||
showCondition: () => true
|
||||
},
|
||||
// 仓库ID:仅状态0/1显示
|
||||
{
|
||||
label: '仓库ID',
|
||||
key: 'warehouseName',
|
||||
showCondition: (status) => status !== CODE_STATUS.OUT_STOCK
|
||||
},
|
||||
// 来源仓库:仅状态0/1且有fromWarehouseId时显示
|
||||
{
|
||||
label: '来源仓库',
|
||||
key: 'fromWarehouseName',
|
||||
showCondition: (status, result) => status !== CODE_STATUS.OUT_STOCK && result.fromWarehouseId
|
||||
},
|
||||
// 物品名称:所有状态显示
|
||||
{
|
||||
label: '物品名称',
|
||||
key: 'itemName',
|
||||
showCondition: () => true
|
||||
},
|
||||
// 物品编码:所有状态显示
|
||||
{
|
||||
label: '物品编码',
|
||||
key: 'itemCode',
|
||||
showCondition: () => true
|
||||
},
|
||||
// 批次号:所有状态显示
|
||||
{
|
||||
label: '批次号',
|
||||
key: 'batchNo',
|
||||
showCondition: () => true
|
||||
},
|
||||
// 库存单ID:仅状态0/1显示
|
||||
{
|
||||
label: '库存单ID',
|
||||
key: 'stockIoId', // 状态1时也用stockIoId,无需额外判断
|
||||
showCondition: (status) => status !== CODE_STATUS.OUT_STOCK
|
||||
}
|
||||
|
||||
// 新增字段:直接在这里加配置,模板无需修改
|
||||
// 示例:
|
||||
// {
|
||||
// label: '有效期',
|
||||
// key: 'expireDate',
|
||||
// showCondition: () => true
|
||||
// }
|
||||
];
|
||||
}
|
||||
}
|
||||
};
|
||||
</script>
|
||||
|
||||
<style scoped>
|
||||
/* 原有样式不变,仅保留隔离的scoped样式 */
|
||||
.result-card { width: 680rpx; background: #fff; border-radius: 20rpx; box-shadow: 0 4rpx 15rpx rgba(0,0,0,0.05); overflow: hidden; }
|
||||
.result-header { padding: 30rpx; border-bottom: 1px solid #f0f0f0; display: flex; justify-content: space-between; align-items: center; }
|
||||
.result-title { font-size: 34rpx; color: #333; font-weight: bold; }
|
||||
.result-time { font-size: 24rpx; color: #999; }
|
||||
.result-body { padding: 30rpx; }
|
||||
.info-item { display: flex; padding: 15rpx 0; border-bottom: 1px dashed #f0f0f0; align-items: flex-start; }
|
||||
.info-item:last-child { border-bottom: none; }
|
||||
.info-label { font-size: 28rpx; color: #666; width: 200rpx; font-weight: 500; flex-shrink: 0; }
|
||||
.info-value { font-size: 28rpx; color: #333; flex: 1; word-break: break-all; }
|
||||
</style>
|
||||
167
apps/hand-factory/components/uni-section/uni-section.vue
Normal file
167
apps/hand-factory/components/uni-section/uni-section.vue
Normal file
@@ -0,0 +1,167 @@
|
||||
<template>
|
||||
<view class="uni-section">
|
||||
<view class="uni-section-header" @click="onClick">
|
||||
<view class="uni-section-header__decoration" v-if="type" :class="type" />
|
||||
<slot v-else name="decoration"></slot>
|
||||
|
||||
<view class="uni-section-header__content">
|
||||
<text :style="{'font-size':titleFontSize,'color':titleColor}" class="uni-section__content-title" :class="{'distraction':!subTitle}">{{ title }}</text>
|
||||
<text v-if="subTitle" :style="{'font-size':subTitleFontSize,'color':subTitleColor}" class="uni-section-header__content-sub">{{ subTitle }}</text>
|
||||
</view>
|
||||
|
||||
<view class="uni-section-header__slot-right">
|
||||
<slot name="right"></slot>
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<view class="uni-section-content" :style="{padding: _padding}">
|
||||
<slot />
|
||||
</view>
|
||||
</view>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
|
||||
/**
|
||||
* Section 标题栏
|
||||
* @description 标题栏
|
||||
* @property {String} type = [line|circle|square] 标题装饰类型
|
||||
* @value line 竖线
|
||||
* @value circle 圆形
|
||||
* @value square 正方形
|
||||
* @property {String} title 主标题
|
||||
* @property {String} titleFontSize 主标题字体大小
|
||||
* @property {String} titleColor 主标题字体颜色
|
||||
* @property {String} subTitle 副标题
|
||||
* @property {String} subTitleFontSize 副标题字体大小
|
||||
* @property {String} subTitleColor 副标题字体颜色
|
||||
* @property {String} padding 默认插槽 padding
|
||||
*/
|
||||
|
||||
export default {
|
||||
name: 'UniSection',
|
||||
emits:['click'],
|
||||
props: {
|
||||
type: {
|
||||
type: String,
|
||||
default: ''
|
||||
},
|
||||
title: {
|
||||
type: String,
|
||||
required: true,
|
||||
default: ''
|
||||
},
|
||||
titleFontSize: {
|
||||
type: String,
|
||||
default: '14px'
|
||||
},
|
||||
titleColor:{
|
||||
type: String,
|
||||
default: '#333'
|
||||
},
|
||||
subTitle: {
|
||||
type: String,
|
||||
default: ''
|
||||
},
|
||||
subTitleFontSize: {
|
||||
type: String,
|
||||
default: '12px'
|
||||
},
|
||||
subTitleColor: {
|
||||
type: String,
|
||||
default: '#999'
|
||||
},
|
||||
padding: {
|
||||
type: [Boolean, String],
|
||||
default: false
|
||||
}
|
||||
},
|
||||
computed:{
|
||||
_padding(){
|
||||
if(typeof this.padding === 'string'){
|
||||
return this.padding
|
||||
}
|
||||
|
||||
return this.padding?'10px':''
|
||||
}
|
||||
},
|
||||
watch: {
|
||||
title(newVal) {
|
||||
if (uni.report && newVal !== '') {
|
||||
uni.report('title', newVal)
|
||||
}
|
||||
}
|
||||
},
|
||||
methods: {
|
||||
onClick() {
|
||||
this.$emit('click')
|
||||
}
|
||||
}
|
||||
}
|
||||
</script>
|
||||
<style lang="scss" >
|
||||
$uni-primary: #2979ff !default;
|
||||
|
||||
.uni-section {
|
||||
background-color: #fff;
|
||||
.uni-section-header {
|
||||
position: relative;
|
||||
/* #ifndef APP-NVUE */
|
||||
display: flex;
|
||||
/* #endif */
|
||||
flex-direction: row;
|
||||
align-items: center;
|
||||
padding: 12px 10px;
|
||||
font-weight: normal;
|
||||
|
||||
&__decoration{
|
||||
margin-right: 6px;
|
||||
background-color: $uni-primary;
|
||||
&.line {
|
||||
width: 4px;
|
||||
height: 12px;
|
||||
border-radius: 10px;
|
||||
}
|
||||
|
||||
&.circle {
|
||||
width: 8px;
|
||||
height: 8px;
|
||||
border-top-right-radius: 50px;
|
||||
border-top-left-radius: 50px;
|
||||
border-bottom-left-radius: 50px;
|
||||
border-bottom-right-radius: 50px;
|
||||
}
|
||||
|
||||
&.square {
|
||||
width: 8px;
|
||||
height: 8px;
|
||||
}
|
||||
}
|
||||
|
||||
&__content {
|
||||
/* #ifndef APP-NVUE */
|
||||
display: flex;
|
||||
/* #endif */
|
||||
flex-direction: column;
|
||||
flex: 1;
|
||||
color: #333;
|
||||
|
||||
.distraction {
|
||||
flex-direction: row;
|
||||
align-items: center;
|
||||
}
|
||||
&-sub {
|
||||
margin-top: 2px;
|
||||
}
|
||||
}
|
||||
|
||||
&__slot-right{
|
||||
font-size: 14px;
|
||||
}
|
||||
}
|
||||
|
||||
.uni-section-content{
|
||||
font-size: 14px;
|
||||
}
|
||||
}
|
||||
</style>
|
||||
Reference in New Issue
Block a user