|
@@ -1,35 +1,97 @@
|
|
|
-import { Component, OnInit } from '@angular/core';
|
|
|
+
|
|
|
+import { Component, NgModule, OnInit } from '@angular/core';
|
|
|
import { CommonModule } from '@angular/common';
|
|
|
import { FormsModule } from '@angular/forms';
|
|
|
-import { IonContent, IonHeader, IonTitle, IonToolbar, IonButton, IonLabel, IonItem, IonList, IonBackButton, IonButtons, IonIcon, IonItemDivider, IonAvatar, IonThumbnail, IonItemOptions, IonItemOption, IonItemSliding, IonInput, IonCheckbox, IonRadio, IonToggle, IonRadioGroup, IonSearchbar,IonSegment,IonSegmentButton,IonDatetime,IonFooter,IonCardContent,IonCardTitle,IonCardHeader,IonCard,IonCol,IonRow,IonGrid,IonChip,IonText } from '@ionic/angular/standalone';
|
|
|
+import { addIcons } from 'ionicons';
|
|
|
+import { camera,trendingUpOutline,sparklesOutline,cloudyOutline,diceOutline} from 'ionicons/icons';
|
|
|
+import { IonContent, IonHeader, IonTitle, IonToolbar, IonButton, IonLabel, IonItem, IonList, IonBackButton, IonButtons, IonIcon, IonItemDivider, IonAvatar, IonThumbnail, IonItemOptions, IonItemOption, IonItemSliding, IonInput, IonCheckbox, IonRadio, IonToggle, IonRadioGroup, IonSearchbar,IonSegment,IonSegmentButton,IonDatetime,IonFooter,IonCardContent,IonCardTitle,IonCardHeader,IonCard,IonCol,IonRow,IonGrid,IonChip,IonTabButton,IonListHeader,ItemReorderEventDetail, IonTabBar, IonTabs,IonCardSubtitle,IonImg,IonBadge } from '@ionic/angular/standalone';
|
|
|
+addIcons({camera,trendingUpOutline,sparklesOutline,cloudyOutline,diceOutline})
|
|
|
|
|
|
+import * as echarts from 'echarts';
|
|
|
@Component({
|
|
|
selector: 'app-community',
|
|
|
templateUrl: './community.page.html',
|
|
|
styleUrls: ['./community.page.scss'],
|
|
|
standalone: true,
|
|
|
- imports: [IonContent, IonHeader, IonTitle, IonToolbar, CommonModule, FormsModule, IonButton, IonLabel, IonLabel, IonList, IonItem, IonBackButton, IonButtons, IonIcon, IonItemDivider, IonAvatar, IonThumbnail, IonItemOptions, IonItemSliding, IonItemOption, IonItemOptions,IonInput,IonCheckbox,IonRadio,IonToggle,IonRadioGroup,IonSearchbar,IonSegment,IonSegmentButton,IonDatetime,IonFooter,IonCardContent,IonCardTitle,IonCardHeader,IonCard,IonCol,IonRow,IonGrid,IonChip,IonText ]
|
|
|
+ imports: [IonContent, IonHeader, IonTitle, IonToolbar, CommonModule, FormsModule, IonButton, IonLabel, IonLabel, IonList, IonItem, IonBackButton, IonButtons, IonIcon, IonItemDivider, IonAvatar, IonThumbnail, IonItemOptions, IonItemSliding, IonItemOption, IonItemOptions,IonInput,IonCheckbox,IonRadio,IonToggle,IonRadioGroup,IonSearchbar,IonSegment,IonSegmentButton,IonDatetime,IonFooter,IonCardContent,IonCardTitle,IonCardHeader,IonCard,IonCol,IonRow,IonGrid,IonChip,IonTabButton,IonTabBar,IonTabs,IonListHeader,IonCardSubtitle,IonImg,IonBadge ]
|
|
|
+
|
|
|
})
|
|
|
+
|
|
|
+
|
|
|
export class CommunityPage implements OnInit {
|
|
|
|
|
|
constructor() { }
|
|
|
|
|
|
ngOnInit() {
|
|
|
+
|
|
|
+ this.initEchart();
|
|
|
}
|
|
|
- // interface Post {
|
|
|
- // id: number;
|
|
|
- // title: string;
|
|
|
- // author: string;
|
|
|
- // contentSnippet: string;
|
|
|
- // avatarUrl: string;
|
|
|
- // timestamp: Date;
|
|
|
- // }
|
|
|
-
|
|
|
- // // 然后,使用这个接口来类型化posts数组
|
|
|
- // posts: Post[] = [
|
|
|
- // { id: 1, title: '帖子标题1', author: '作者1', contentSnippet: '内容摘要1', avatarUrl: 'url_to_avatar1', timestamp: new Date() },
|
|
|
- // { id: 2, title: '帖子标题2', author: '作者2', contentSnippet: '内容摘要2', avatarUrl: 'url_to_avatar2', timestamp: new Date() },
|
|
|
- // { id: 3, title: '帖子标题3', author: '作者3', contentSnippet: '内容摘要3', avatarUrl: 'url_to_avatar3', timestamp: new Date() },
|
|
|
- // ];
|
|
|
-
|
|
|
-}
|
|
|
+ public chart: any;
|
|
|
+ initEchart() {
|
|
|
+ let ec = echarts as any;
|
|
|
+ let container = document.getElementById('chart');
|
|
|
+ this.chart = ec.init(container);
|
|
|
+ let option = {
|
|
|
+ tooltip: {
|
|
|
+ trigger: 'axis'
|
|
|
+ },
|
|
|
+ legend: {
|
|
|
+ data: ['邮件营销', '联盟广告', '视频广告', '直接访问', '搜索引擎']
|
|
|
+ },
|
|
|
+ grid: {
|
|
|
+ left: "2%",
|
|
|
+ right: "3%",
|
|
|
+ bottom: "1%",
|
|
|
+ borderWidth:10,
|
|
|
+ containLabel: true
|
|
|
+ },
|
|
|
+ toolbox: {
|
|
|
+ feature: {
|
|
|
+ saveAsImage: {}
|
|
|
+ }
|
|
|
+ },
|
|
|
+ xAxis: {
|
|
|
+ type: 'category',
|
|
|
+ boundaryGap: false,
|
|
|
+ data: ['周一', '周二', '周三', '周四', '周五', '周六', '周日']
|
|
|
+ },
|
|
|
+ yAxis: {
|
|
|
+ type: 'value'
|
|
|
+ },
|
|
|
+ series: [
|
|
|
+ {
|
|
|
+ name: '邮件营销',
|
|
|
+ type: 'line',
|
|
|
+ stack: '总量',
|
|
|
+ data: [120, 132, 101, 134, 90, 230, 210]
|
|
|
+ },
|
|
|
+ {
|
|
|
+ name: '联盟广告',
|
|
|
+ type: 'line',
|
|
|
+ stack: '总量',
|
|
|
+ data: [220, 182, 191, 234, 290, 330, 310]
|
|
|
+ },
|
|
|
+ {
|
|
|
+ name: '视频广告',
|
|
|
+ type: 'line',
|
|
|
+ stack: '总量',
|
|
|
+ data: [150, 232, 201, 154, 190, 330, 410]
|
|
|
+ },
|
|
|
+ {
|
|
|
+ name: '直接访问',
|
|
|
+ type: 'line',
|
|
|
+ stack: '总量',
|
|
|
+ data: [320, 332, 301, 334, 390, 330, 320]
|
|
|
+ },
|
|
|
+ {
|
|
|
+ name: '搜索引擎',
|
|
|
+ type: 'line',
|
|
|
+ stack: '总量',
|
|
|
+ data: [820, 932, 901, 934, 1290, 1330, 1320]
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ };
|
|
|
+
|
|
|
+ this.chart.setOption(option);
|
|
|
+}}
|
|
|
+
|