陈鹏飞 3 years ago
parent
commit
58c7e62c51
  1. 35
      src/app/app.component.ts
  2. 26
      src/app/babylon/controller/data-manager.ts
  3. 9
      src/app/babylon/controller/serve-manager.ts
  4. 1
      src/app/babylon/tool/speaking-tool.ts
  5. 2
      src/app/pages/criminal-records-admin/criminal-records-admin.component.html
  6. 151
      src/app/pages/criminal-records-admin/criminal-records-admin.component.ts
  7. 2
      src/app/pages/criminal-records/criminal-records.component.html
  8. 150
      src/app/pages/criminal-records/criminal-records.component.ts
  9. 13
      src/app/pages/home/home.component.ts
  10. 8
      src/app/pages/login/login.component.html
  11. 21
      src/app/pages/login/login.component.scss
  12. 1
      src/app/pages/login/login.component.ts
  13. 2
      src/app/pages/plan-admin/plan-admin.component.html
  14. 46
      src/app/pages/plan-admin/plan-admin.component.ts
  15. 1
      src/app/system-management/navigation/navigation.component.html
  16. 3
      src/app/system-management/navigation/navigation.component.ts
  17. 8
      src/app/ui/tabbar/tabbar.component.html
  18. 13
      src/app/ui/tabbar/tabbar.component.ts
  19. BIN
      src/assets/images/logo2.png
  20. 896
      src/assets/js/abp.js
  21. 4
      src/index.html

35
src/app/app.component.ts

@ -7,7 +7,7 @@ import { CookieService } from 'ngx-cookie-service';
import "reflect-metadata";
import { NzNotificationService } from 'ng-zorro-antd/notification';
declare var abp:any
@Component({
selector: 'app-root',
templateUrl: './app.component.html',
@ -17,7 +17,7 @@ export class AppComponent {
@ViewChild(TemplateRef, { static: false }) template?: TemplateRef<{}>;
constructor(private http: HttpClient, private router: Router, public token: CacheTokenService, private cookieService: CookieService,private notificationService: NzNotificationService) { }
constructor(private http: HttpClient, private router: Router, public token: CacheTokenService, private cookieService: CookieService, private notificationService: NzNotificationService) { }
ngOnInit(): void {
// var token = this.cookieService.get("token")
@ -30,11 +30,38 @@ export class AppComponent {
// this.token.startUp()
// })
// }
console.log('abp',abp)
}
receiptOfNotification() {
this.notificationService.template(this.template!, { nzPlacement: 'bottomRight', nzClass: 'receiptOfNotification',nzDuration: 0 });
this.notificationService.template(this.template!, { nzPlacement: 'bottomRight', nzClass: 'receiptOfNotification', nzDuration: 0 });
}
messages
abp() {
let _this = this;
//手动实现hub
//this.hubConnection = new signalR.HubConnectionBuilder()
// .withUrl('/signalr-violation',
// {
// accessTokenFactory: ()=>this.token
// }
// )
// .build();
////服务器回调方法
//this.hubConnection.on('SendViolation', (data) => {
// console.log("SendViolation", data);
// _this.messages.push("SendViolation:"+JSON.stringify(data));
//});
//this.hubConnection.start();
//abp封装的hub
abp.event.on('abp.notifications.received', function (userNotification) {
_this.messages.push("abp.notifications.received:" + JSON.stringify(userNotification));
console.log('abp.notifications.received', userNotification);
});
}
}

26
src/app/babylon/controller/data-manager.ts

@ -305,6 +305,25 @@ export class DataManager {
return result;
}
/**
*
* @param institutionKey id
* @param resType
* @param key key
*/
static getResPath_mark(institutionKey: string, resType: ResType, key: string) {
let result =
institutionKey.toLocaleLowerCase() +
'/' +
ServeManager.ngAssetsPath +
"mark/" + //表示是应急标绘下的
resType +
'/' +
key +
'/';
return result;
}
// //获取设备资源完整路径
// static getResPath_facility(facilityPosType: FacilityPosType, type: FacilityType): string {
// let result = "mesh/facilities/";
@ -587,5 +606,12 @@ export enum ModelChangeType {
Update,
}
/**
*
*/
export enum ResType {
Texture = "texture",
Video = "video",
}

9
src/app/babylon/controller/serve-manager.ts

@ -158,7 +158,14 @@ export class ServeManager {
//#region 文件上传
//队列性,批量上传
/**
*
* @param index
* @param files
* @param resPath_out
* @param onOneSuccess
* @param onEnd
*/
uploadFile(index: number, files: File[], resPath_out, onOneSuccess: (name: string, path: string, file: File) => void, onEnd: () => void) {
if (index < files.length) {
console.log("上传文件", files[index].name);

1
src/app/babylon/tool/speaking-tool.ts

@ -20,6 +20,7 @@ export class SpeakingTool {
* @param msg
*/
speak(msg: string) {
console.log("阅读" + msg);
if (this.isIE()) {
}

2
src/app/pages/criminal-records-admin/criminal-records-admin.component.html

@ -68,7 +68,7 @@
</span>
<div class="centerContent">
<div class="numname">预警事件总数</div>
<div class="num">206</div>
<div class="num">{{num}}</div>
</div>
<div class="piechart" id="piechart">

151
src/app/pages/criminal-records-admin/criminal-records-admin.component.ts

@ -49,26 +49,7 @@ export class CriminalRecordsAdminComponent implements OnInit {
}
},
data: [
{ value: 26, name: '工作人员倚靠加油机或者立柱1' },
{ value: 86, name: '工作人员倚靠加油机或者立柱2' },
{ value: 34, name: '工作人员倚靠加油机或者立柱3' },
{ value: 55, name: '工作人员倚靠加油机或者立柱4' },
{ value: 60, name: '工作人员倚靠加油机或者立柱5' },
{ value: 26, name: '工作人员倚靠加油机或者立柱6' },
{ value: 86, name: '工作人员倚靠加油机或者立柱7' },
{ value: 34, name: '工作人员倚靠加油机或者立柱8' },
{ value: 55, name: '工作人员倚靠加油机或者立柱9' },
{ value: 60, name: '工作人员倚靠加油机或者立柱10' },
{ value: 26, name: '工作人员倚靠加油机或者立柱11' },
{ value: 86, name: '工作人员倚靠加油机或者立柱12' },
{ value: 34, name: '工作人员倚靠加油机或者立柱13' },
{ value: 55, name: '工作人员倚靠加油机或者立柱14' },
{ value: 60, name: '工作人员倚靠加油机或者立柱15' },
{ value: 26, name: '工作人员倚靠加油机或者立柱16' },
{ value: 86, name: '工作人员倚靠加油机或者立柱17' },
{ value: 34, name: '工作人员倚靠加油机或者立柱18' },
{ value: 55, name: '工作人员倚靠加油机或者立柱19' },
{ value: 60, name: '工作人员倚靠加油机或者立柱20' }
],
tooltip: {//鼠标移入提示
position: 'right',
@ -87,7 +68,7 @@ export class CriminalRecordsAdminComponent implements OnInit {
baroption = {
xAxis: {
type: 'category',
data: this.getThirtyDays(),
data: [],
axisLine: {
show: false,
lineStyle: {
@ -96,7 +77,8 @@ export class CriminalRecordsAdminComponent implements OnInit {
},
axisTick: {//刻度线
show: false
}
},
inverse: true
},
yAxis: {
type: 'value',
@ -121,7 +103,7 @@ export class CriminalRecordsAdminComponent implements OnInit {
},
series: [
{
data: [120, 200, 150, 80, 70, 110, 130, 120, 200, 150, 80, 70, 110, 130, 120, 200, 150, 80, 70, 110, 130, 120, 200, 150, 80, 70, 110, 130, 100, 101],
data: [],
type: 'bar',
itemStyle: {
color: {
@ -141,7 +123,7 @@ export class CriminalRecordsAdminComponent implements OnInit {
barWidth: '25%'
},
{
data: [120, 200, 150, 80, 70, 110, 130, 120, 200, 150, 80, 70, 110, 130, 120, 200, 150, 80, 70, 110, 130, 120, 200, 150, 80, 70, 110, 130, 100, 101],
data: [],
type: 'line',
symbol: 'circle',
symbolSize: 8,
@ -173,7 +155,7 @@ export class CriminalRecordsAdminComponent implements OnInit {
},
yAxis: {
type: 'category',
data: ['北京市第十九加油站1', '北京市第十九加油站2', '北京市第十九加油站3', '北京市第十九加油站4', '北京市第十九加油站5', '北京市第十九加油站6', '北京市第十九加油站7', '北京市第十九加油站8', '北京市第十九加油站9', '北京市第十九加油站10', '北京市第十九加油站11', '北京市第十九加油站12', '北京市第十九加油站', '北京市第十九加油站', '北京市第十九加油站', '北京市第十九加油站', '北京市第十九加油站', '北京市第十九加油站', '北京市第十九加油站', '北京市第十九加油站20', '北京市第十九加油站21', '北京市第十九加油站22', '北京市第十九加油站23'],
data: [],
axisLine: {
show: false,
lineStyle: {
@ -185,8 +167,27 @@ export class CriminalRecordsAdminComponent implements OnInit {
},
axisLabel: {
formatter: function (value, index) {
let newParamsName = '';
const paramsNameNumber = value.length;
const provideNumber = 10;
const rowNumber = Math.ceil(paramsNameNumber / provideNumber);
if (paramsNameNumber > provideNumber) {
for (let p = 0; p < rowNumber; p++) {
let tempStr = '';
const start = p * provideNumber;
const end = start + provideNumber;
if (p == rowNumber - 1) {
tempStr = value.substring(start, paramsNameNumber);
} else {
tempStr = value.substring(start, end) + '\n';
}
newParamsName += tempStr;
}
} else {
newParamsName = value;
}
// 格式化成月/日,只在第一个刻度显示年份
return '{s|·}' + `{a|${value}}`;
return '{s|·}' + `{a|${newParamsName}}`;
},
rich: {
a: {
@ -219,7 +220,7 @@ export class CriminalRecordsAdminComponent implements OnInit {
formatter: '{c}',
offset: [6, 0]
},
data: [40, 36, 30, 25, 19, 15, 14, 11, 10, 8, 40, 36, 30, 25, 19, 15, 14, 11, 10, 8, 1, 2, 3].reverse(),
data: [],
type: 'bar',
itemStyle: {
color: {
@ -278,7 +279,6 @@ export class CriminalRecordsAdminComponent implements OnInit {
startdate
enddate
ngOnInit(): void {
//当前日期
let myDate: any = new Date();
let nowY = myDate.getFullYear();
@ -309,7 +309,85 @@ export class CriminalRecordsAdminComponent implements OnInit {
this.warningType()
this.getViolateRecordList()
}
//刷新饼图图表数据
num
echartsData: any
refreshPieData(data) {
//饼图
let option = this.myChart.getOption();
var num = 0
data.pieTop.forEach(element => {
num += element.count
element.name = element.key
element.value = element.count
});
this.num = num
option.series[0].data = data.pieTop;
this.myChart.setOption(option);
}
//刷新柱状折线图表数据
refreshBarLineData(data, type) {
console.log('统计图表数据', data)
//柱状图
let option = this.mybarChart.getOption();
console.log('柱图option', option)
if (type == 'month') {//近一个月柱状折线图
option = this.baroption
let monthArr = []
let valuedata = []
data.timeTop.forEach(element => {
monthArr.push(moment(element.key).format('MM.DD'))
valuedata.push(element.count)
});
option.xAxis.data = monthArr
option.series[0].data = valuedata
option.series[1].data = valuedata
} else if (type == 'eventTop') {
option = this.baroption2
let ydata = []
let valuedata = []
data.eventTop.forEach(element => {
ydata.push(element.key)
valuedata.push(element.count)
});
option.yAxis.data = ydata
option.series.data = valuedata
} else if (type == 'siteTop') {
option = this.baroption2
let ydata = []
let valuedata = []
data.siteTop.forEach(element => {
ydata.push(element.key)
valuedata.push(element.count)
});
option.yAxis.data = ydata
option.series.data = valuedata
}
this.mybarChart.setOption(option);
}
//获取统计信息
getAggregations() {
let ViolationIds = []
if (this.validateForm.value.type) {
this.warningTypesDetails.forEach(item => {
item.id ? ViolationIds.push(item.id) : null
});
}
let body: any = {
organizationUnitId: JSON.parse(sessionStorage.getItem('userdata')).organization.id,
isContainsChildren: true,
ViolateTime: this.validateForm.value.datePicker ? [moment(this.validateForm.value.datePicker[0]).format('yyyy-MM-DD'), moment(this.validateForm.value.datePicker[1]).format('yyyy-MM-DD')] : null
}
this.validateForm.value.level ? body.level = this.validateForm.value.level : null
this.validateForm.value.site ? body.violateArea = this.validateForm.value.site : null
ViolationIds.length != 0 ? body.violationType = ViolationIds : null
this.http.post('/api/services/app/ViolateRecord/Aggregations', body).subscribe((data: any) => {
this.echartsData = data.result
this.refreshPieData(data.result)
this.refreshBarLineData(this.echartsData, 'month')
})
}
//获得违规记录列表
SkipCount: string = '0'
MaxResultCount: string = '50'
@ -340,6 +418,7 @@ export class CriminalRecordsAdminComponent implements OnInit {
// this.list = data.result.items
this.totalCount = data.result.totalCount
console.log('违规记录列表', data)
this.getAggregations()
})
}
@ -466,13 +545,25 @@ export class CriminalRecordsAdminComponent implements OnInit {
this.mybarChart.dispose()
this.mybarChart = echarts.init(document.getElementById('barchart'));
if (type == '排名') {
this.mybarChart.setOption(this.baroption2);
console.log(this.selectedRankingType)
if (this.selectedRankingType == '站点排名') {
this.refreshBarLineData(this.echartsData, 'siteTop')
}
if (this.selectedRankingType == '事件排名') {
this.refreshBarLineData(this.echartsData, 'eventTop')
}
} else {
this.mybarChart.setOption(this.baroption);
this.refreshBarLineData(this.echartsData, 'month')
}
}
echartClick2(type) {
this.selectedRankingType = type
if (this.selectedRankingType == '站点排名') {
this.refreshBarLineData(this.echartsData, 'siteTop')
}
if (this.selectedRankingType == '事件排名') {
this.refreshBarLineData(this.echartsData, 'eventTop')
}
}
}

2
src/app/pages/criminal-records/criminal-records.component.html

@ -68,7 +68,7 @@
</span>
<div class="centerContent">
<div class="numname">预警事件总数</div>
<div class="num">206</div>
<div class="num">{{num}}</div>
</div>
<div class="piechart" id="piechart">

150
src/app/pages/criminal-records/criminal-records.component.ts

@ -45,26 +45,6 @@ export class CriminalRecordsComponent implements OnInit {
}
},
data: [
{ value: 26, name: '工作人员倚靠加油机或者立柱1' },
{ value: 86, name: '工作人员倚靠加油机或者立柱2' },
{ value: 34, name: '工作人员倚靠加油机或者立柱3' },
{ value: 55, name: '工作人员倚靠加油机或者立柱4' },
{ value: 60, name: '工作人员倚靠加油机或者立柱5' },
{ value: 26, name: '工作人员倚靠加油机或者立柱6' },
{ value: 86, name: '工作人员倚靠加油机或者立柱7' },
{ value: 34, name: '工作人员倚靠加油机或者立柱8' },
{ value: 55, name: '工作人员倚靠加油机或者立柱9' },
{ value: 60, name: '工作人员倚靠加油机或者立柱10' },
{ value: 26, name: '工作人员倚靠加油机或者立柱11' },
{ value: 86, name: '工作人员倚靠加油机或者立柱12' },
{ value: 34, name: '工作人员倚靠加油机或者立柱13' },
{ value: 55, name: '工作人员倚靠加油机或者立柱14' },
{ value: 60, name: '工作人员倚靠加油机或者立柱15' },
{ value: 26, name: '工作人员倚靠加油机或者立柱16' },
{ value: 86, name: '工作人员倚靠加油机或者立柱17' },
{ value: 34, name: '工作人员倚靠加油机或者立柱18' },
{ value: 55, name: '工作人员倚靠加油机或者立柱19' },
{ value: 60, name: '工作人员倚靠加油机或者立柱20' }
],
tooltip: {//鼠标移入提示
position: 'right',
@ -84,7 +64,7 @@ export class CriminalRecordsComponent implements OnInit {
baroption = {
xAxis: {
type: 'category',
data: this.getThirtyDays(),
data: [],
axisLine: {
show: false,
lineStyle: {
@ -93,7 +73,9 @@ export class CriminalRecordsComponent implements OnInit {
},
axisTick: {//刻度线
show: false
}
},
inverse: true
},
yAxis: {
type: 'value',
@ -118,7 +100,7 @@ export class CriminalRecordsComponent implements OnInit {
},
series: [
{
data: [120, 200, 150, 80, 70, 110, 130, 120, 200, 150, 80, 70, 110, 130, 120, 200, 150, 80, 70, 110, 130, 120, 200, 150, 80, 70, 110, 130, 100, 101],
data: [],
type: 'bar',
itemStyle: {
color: {
@ -138,7 +120,7 @@ export class CriminalRecordsComponent implements OnInit {
barWidth: '25%'
},
{
data: [120, 200, 150, 80, 70, 110, 130, 120, 200, 150, 80, 70, 110, 130, 120, 200, 150, 80, 70, 110, 130, 120, 200, 150, 80, 70, 110, 130, 100, 101],
data: [],
type: 'line',
symbol: 'circle',
symbolSize: 8,
@ -170,7 +152,7 @@ export class CriminalRecordsComponent implements OnInit {
},
yAxis: {
type: 'category',
data: ['预警事件名', '预警事件名', '预警事件名', '预警事件名', '预警事件名', '预警事件名', '预警事件名', '预警事件名', '预警事件名', '预警事件名'],
data: [],
axisLine: {
show: false,
lineStyle: {
@ -182,8 +164,27 @@ export class CriminalRecordsComponent implements OnInit {
},
axisLabel: {
formatter: function (value, index) {
let newParamsName = '';
const paramsNameNumber = value.length;
const provideNumber = 10;
const rowNumber = Math.ceil(paramsNameNumber / provideNumber);
if (paramsNameNumber > provideNumber) {
for (let p = 0; p < rowNumber; p++) {
let tempStr = '';
const start = p * provideNumber;
const end = start + provideNumber;
if (p == rowNumber - 1) {
tempStr = value.substring(start, paramsNameNumber);
} else {
tempStr = value.substring(start, end) + '\n';
}
newParamsName += tempStr;
}
} else {
newParamsName = value;
}
// 格式化成月/日,只在第一个刻度显示年份
return '{s|·}' + `{a|${value}}`;
return '{s|·}' + `{a|${newParamsName}}`;
},
rich: {
a: {
@ -201,8 +202,8 @@ export class CriminalRecordsComponent implements OnInit {
shadowColor: "#fff"
}
}
}
},
inverse: true
},
series:
{
@ -215,7 +216,7 @@ export class CriminalRecordsComponent implements OnInit {
formatter: '{c}',
offset: [6, 0]
},
data: [40, 36, 30, 25, 19, 15, 14, 11, 10, 8].reverse(),
data: [],
type: 'bar',
itemStyle: {
color: {
@ -237,8 +238,8 @@ export class CriminalRecordsComponent implements OnInit {
}
,
grid: {
left: '100px',
right: '60px',
left: '150px',
right: '80px',
bottom: '3px',
top: '20px'
}
@ -312,6 +313,87 @@ export class CriminalRecordsComponent implements OnInit {
this.warningType()
this.getViolateRecordList()
}
//刷新饼图图表数据
num
echartsData: any
refreshPieData(data) {
//饼图
let option = this.myChart.getOption();
var num = 0
data.pieTop.forEach(element => {
num += element.count
element.name = element.key
element.value = element.count
});
this.num = num
option.series[0].data = data.pieTop;
this.myChart.setOption(option);
}
//刷新柱状折线图表数据
refreshBarLineData(data, type) {
console.log('统计图表数据', data)
//柱状图
let option = this.mybarChart.getOption();
console.log('柱图option', option)
if (type == 'month') {//近一个月柱状折线图
option = this.baroption
let monthArr = []
let valuedata = []
data.timeTop.forEach(element => {
monthArr.push(moment(element.key).format('MM.DD'))
valuedata.push(element.count)
});
option.xAxis.data = monthArr
option.series[0].data = valuedata
option.series[1].data = valuedata
} else if (type == 'eventTop') {
option = this.baroption2
let ydata = []
let valuedata = []
data.eventTop.forEach(element => {
ydata.push(element.key)
valuedata.push(element.count)
});
option.yAxis.data = ydata
option.series.data = valuedata
} else if (type == 'siteTop') {
option = this.baroption2
let ydata = []
let valuedata = []
data.siteTop.forEach(element => {
ydata.push(element.key)
valuedata.push(element.count)
});
option.yAxis.data = ydata
option.series.data = valuedata
}
this.mybarChart.setOption(option);
}
//获取统计信息
getAggregations() {
let ViolationIds = []
if (this.validateForm.value.type) {
this.warningTypesDetails.forEach(item => {
item.id ? ViolationIds.push(item.id) : null
});
}
let body: any = {
organizationUnitId: JSON.parse(sessionStorage.getItem('userdataOfgasstation')).organization.id,
isContainsChildren: true,
ViolateTime: this.validateForm.value.datePicker ? [moment(this.validateForm.value.datePicker[0]).format('yyyy-MM-DD'), moment(this.validateForm.value.datePicker[1]).format('yyyy-MM-DD')] : null
}
this.validateForm.value.level ? body.level = this.validateForm.value.level : null
this.validateForm.value.site ? body.violateArea = this.validateForm.value.site : null
ViolationIds.length != 0 ? body.violationType = ViolationIds : null
this.http.post('/api/services/app/ViolateRecord/Aggregations', body).subscribe((data: any) => {
this.echartsData = data.result
this.refreshPieData(data.result)
this.refreshBarLineData(this.echartsData, 'month')
})
}
//获得违规记录列表
@ -344,6 +426,7 @@ export class CriminalRecordsComponent implements OnInit {
// this.list = data.result.items
this.totalCount = data.result.totalCount
console.log('违规记录列表', data)
this.getAggregations()
})
}
ngAfterViewInit(): void {
@ -405,9 +488,10 @@ export class CriminalRecordsComponent implements OnInit {
this.mybarChart.dispose()
this.mybarChart = echarts.init(document.getElementById('barchart'));
if (type == '排名') {
this.mybarChart.setOption(this.baroption2);
console.log(this.selectedRankingType)
this.refreshBarLineData(this.echartsData, 'eventTop')
} else {
this.mybarChart.setOption(this.baroption);
this.refreshBarLineData(this.echartsData, 'month')
}
}

13
src/app/pages/home/home.component.ts

@ -19,15 +19,22 @@ export class HomeComponent implements OnInit {
this.navChangeService.getMessage().subscribe((message: any) => {
console.log(message);//send a message
if(message.name == 'oilstation'){
if (message.name == 'oilstation') {
this.isGasStationNav = true
}
if(message.name == '改变数量'){
if (message.name == '改变数量') {
this.isWarning = true
this.num = message.num
}
});
if (this.router.url.indexOf('warning') != -1) {
this.isWarning = true
} else {
this.isWarning = false
}
if (this.router.url.indexOf('petrolStation') != -1 && sessionStorage.getItem('isGasStation') == 'false') {//控制返回按钮显示
this.isGasStation = true
} else {
@ -44,7 +51,7 @@ export class HomeComponent implements OnInit {
filter(event => event instanceof NavigationEnd)
).subscribe((event: any) => {
if (event.url.indexOf('warning') != -1) {//控制今日预警左上角数字显示
this.isWarning = true
} else {
this.isWarning = false
}

8
src/app/pages/login/login.component.html

@ -1,6 +1,8 @@
<div class="login" id="login">
<div class="card">
<h1 class="cardheader">欢迎登陆</h1>
<h1 class="cardheader">中化石油智能安全管理系统</h1>
<form nz-form [formGroup]="validateForm" class="login-form" (ngSubmit)="submitForm()">
<nz-form-item>
<nz-form-control nzErrorTip="请输入账号!">
@ -51,9 +53,9 @@
<div class="name">
<img src="../../../assets/images/logo.png" alt="">
<h1>中化石油</h1>
<h1>智能安全管理系统</h1>
<img src="../../../assets/images/logo2.png" alt="">
<!-- <h1>中化石油</h1>
<h1>智能安全管理系统</h1> -->
</div>
</div>

21
src/app/pages/login/login.component.scss

@ -8,8 +8,9 @@
.card {
position: absolute;
top: 20%;
right: 12%;
top: 50%;
left: 50%;
transform: translate(-50%,-50%);
background-color: rgba(0, 13, 33, 0.24);
border-radius: 16px;
width: 456px;
@ -20,10 +21,12 @@
}
.cardheader {
font-size: 28px;
margin-bottom: 66px;
font-size: 22px;
color: rgba(255, 255, 255, 1);
}
.cardheader:nth-child(2) {
margin-bottom: 40px;
}
label {
color: #fff;
@ -33,7 +36,7 @@ label {
display: flex;
justify-content: space-between;
margin-bottom: 6px;
align-items: center;
.forget {
cursor: pointer;
color: #2399FF;
@ -69,11 +72,13 @@ p {
.name {
position: absolute;
left: 10%;
bottom: 45%;
left:40px;
top:40px;
img {
margin-bottom: 32px;
// margin-bottom: 32px;
width: 254px;
height: 56px;
}
h1 {

1
src/app/pages/login/login.component.ts

@ -111,6 +111,7 @@ export class LoginComponent implements OnInit {
//自动登陆
this.autoLogin()
if (data.result.user.userName == 'admin') {
sessionStorage.setItem("isGasStation", 'false');
this.router.navigate(['/system/organization'])
} else {
if (data.result.user.organization.isGasStation) {

2
src/app/pages/plan-admin/plan-admin.component.html

@ -81,7 +81,7 @@
<th>{{item.laneCount}}</th>
<th>{{item.tankVolume}}</th>
<th>
<span class="look" (click)="look()" style="cursor:pointer;color: #36A2FF">查看</span>
<span class="look" (click)="look(item)" style="cursor:pointer;color: #36A2FF">查看</span>
</th>
</tr>
</tbody>

46
src/app/pages/plan-admin/plan-admin.component.ts

@ -33,10 +33,29 @@ export class PlanAdminComponent implements OnInit {
if (event.target.scrollHeight - (event.target.scrollTop + event.target.clientHeight) <= 10) {
console.log('需要加载数据了', event)
this.SkipCount = String(Number(this.SkipCount) + 50)
await this.getGasStation()
// await this.getGasStation()
let params = {
StationName: this.validateForm.value.name,
OrganizationUnitId: String(this.OrganizationUnitId),
IsContainsChildren: 'true',
SkipCount: this.SkipCount,
MaxResultCount: this.MaxResultCount
}
await new Promise((resolve, reject) => {
this.http.get('/api/services/app/GasStation/GetAll', {
params: params
}).subscribe((data: any) => {
this.list = this.list.concat(data.result.items);
this.list = [...this.list]
resolve(data)
})
})
}
});
}
submitForm(): void {
for (const i in this.validateForm.controls) {
this.validateForm.controls[i].markAsDirty();
@ -83,7 +102,7 @@ export class PlanAdminComponent implements OnInit {
let OrganizationUnitId = sessionStorage.getItem('isGasStation') == 'true' ? JSON.parse(sessionStorage.getItem('userdataOfgasstation')).organization.id : JSON.parse(sessionStorage.getItem('userdata')).organization.id
let params = {
OrganizationUnitId: OrganizationUnitId,
IsContainsChildren: "false"
IsContainsChildren: "true"
}
this.http.get('/api/services/app/Organization/GetAll', {
params: params
@ -93,9 +112,9 @@ export class PlanAdminComponent implements OnInit {
element.parentId = null
}
});
// data.result.items = data.result.items.filter((item, i) => {
// return !item.isGasStation
// })
data.result.items = data.result.items.filter((item, i) => {
return !item.isGasStation
})
for (let index = 0; index < data.result.items.length; index++) {
const element = data.result.items[index];
element.key = element.id
@ -115,7 +134,16 @@ export class PlanAdminComponent implements OnInit {
return (document.getElementById('tablebox').clientHeight - 42) + 'px'
}
look() {
look(item) {
let gastionobj = {
organization: {
displayName: item.stationName,
isGasStation: true,
id: item.organizationUnitId
}
}
sessionStorage.setItem('userdataOfgasstation', JSON.stringify(gastionobj))
this.router.navigate(['/plan/petrolStation'])
let obj = {
name: 'oilstation'
@ -150,10 +178,10 @@ export class PlanAdminComponent implements OnInit {
this.http.get('/api/services/app/GasStation/GetAll', {
params: params
}).subscribe((data: any) => {
this.list = this.list.concat(data.result.items);
this.list = [...this.list]
// this.list = this.list.concat(data.result.items);
this.list = [...data.result.items]
resolve(data)
console.log(999999, data)
// console.log(999999, data)
})
})
}

1
src/app/system-management/navigation/navigation.component.html

@ -29,6 +29,7 @@
</a>
<nz-dropdown-menu #menu="nzDropdownMenu">
<ul nz-menu nzSelectable>
<li nz-menu-item (click)="pages()">主页面</li>
<li nz-menu-item (click)="signOut()">退出</li>
</ul>
</nz-dropdown-menu>

3
src/app/system-management/navigation/navigation.component.ts

@ -15,4 +15,7 @@ export class NavigationComponent implements OnInit {
signOut() {
this.router.navigate(['/login'])
}
pages() {
this.router.navigate(['/plan'])
}
}

8
src/app/ui/tabbar/tabbar.component.html

@ -1,6 +1,6 @@
<div class="box">
<div class="boxleft">
<img src="../../../assets/images/logo.png" alt="">
<img style="width: 200px;" src="../../../assets/images/logo2.png" alt="">
</div>
<!-- 登录信息按钮 -->
<div class="boxright">
@ -16,9 +16,9 @@
</a>
<nz-dropdown-menu #menu="nzDropdownMenu">
<ul nz-menu nzSelectable>
<li nz-menu-item (click)="navChange('/oliStationInfo')">基本信息</li>
<li nz-menu-item (click)="navChange('/equipmentInfo')">器材信息</li>
<!-- <li nz-menu-item (click)="navChange('/system/organization')">系统管理</li> -->
<li *ngIf="isGasStation == 'true'" nz-menu-item (click)="navChange('/oliStationInfo')">基本信息</li>
<li *ngIf="isGasStation == 'true'" nz-menu-item (click)="navChange('/equipmentInfo')">器材信息</li>
<li *ngIf="userName == 'admin'" nz-menu-item (click)="navChange('/system/organization')">系统管理</li>
<li nz-menu-item (click)="signOut()">退出系统</li>
</ul>
</nz-dropdown-menu>

13
src/app/ui/tabbar/tabbar.component.ts

@ -17,11 +17,22 @@ export class TabbarComponent implements OnInit {
constructor(private http: HttpClient, private router: Router, private route: ActivatedRoute, public token: CacheTokenService,
private cookieService: CookieService, private message: NzMessageService) { }
surname: string
userName: string
isGasStation: string
ngOnInit() {
setInterval(() => {
this.getTime()
}, 1000);
this.surname = JSON.parse(sessionStorage.getItem('userdata')).name
this.isGasStation = JSON.parse(sessionStorage.getItem('isGasStation'))
if(this.isGasStation == 'true'){
this.surname = JSON.parse(sessionStorage.getItem('userdataOfgasstation')).name
this.userName = JSON.parse(sessionStorage.getItem('userdataOfgasstation')).userName
}else{
this.surname = JSON.parse(sessionStorage.getItem('userdata')).name
this.userName = JSON.parse(sessionStorage.getItem('userdata')).userName
}
}
//获得时间

BIN
src/assets/images/logo2.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 10 KiB

896
src/assets/js/abp.js

@ -0,0 +1,896 @@
var abp = abp || {};
(function () {
/* Application paths *****************************************/
//Current application root path (including virtual directory if exists).
abp.appPath = abp.appPath || '/';
abp.pageLoadTime = new Date();
//Converts given path to absolute path using abp.appPath variable.
abp.toAbsAppPath = function (path) {
if (path.indexOf('/') == 0) {
path = path.substring(1);
}
return abp.appPath + path;
};
/* MULTITENANCY */
abp.multiTenancy = abp.multiTenancy || {};
abp.multiTenancy.isEnabled = false;
abp.multiTenancy.ignoreFeatureCheckForHostUsers = false;
abp.multiTenancy.sides = {
TENANT: 1,
HOST: 2
};
abp.multiTenancy.tenantIdCookieName = 'Abp.TenantId';
abp.multiTenancy.setTenantIdCookie = function (tenantId) {
if (tenantId) {
abp.utils.setCookieValue(
abp.multiTenancy.tenantIdCookieName,
tenantId.toString(),
new Date(new Date().getTime() + 5 * 365 * 86400000), //5 years
abp.appPath,
abp.domain
);
} else {
abp.utils.deleteCookie(abp.multiTenancy.tenantIdCookieName, abp.appPath);
}
};
abp.multiTenancy.getTenantIdCookie = function () {
var value = abp.utils.getCookieValue(abp.multiTenancy.tenantIdCookieName);
if (!value) {
return null;
}
return parseInt(value);
}
/* SESSION */
abp.session = abp.session ||
{
multiTenancySide: abp.multiTenancy.sides.HOST
};
/* LOCALIZATION ***********************************************/
//Implements Localization API that simplifies usage of localization scripts generated by Abp.
abp.localization = abp.localization || {};
abp.localization.languages = [];
abp.localization.currentLanguage = {};
abp.localization.sources = [];
abp.localization.values = {};
abp.localization.localize = function (key, sourceName) {
sourceName = sourceName || abp.localization.defaultSourceName;
var source = abp.localization.values[sourceName];
if (!source) {
abp.log.warn('Could not find localization source: ' + sourceName);
return key;
}
var value = source[key];
if (value == undefined) {
return key;
}
var copiedArguments = Array.prototype.slice.call(arguments, 0);
copiedArguments.splice(1, 1);
copiedArguments[0] = value;
return abp.utils.formatString.apply(this, copiedArguments);
};
abp.localization.getSource = function (sourceName) {
return function (key) {
var copiedArguments = Array.prototype.slice.call(arguments, 0);
copiedArguments.splice(1, 0, sourceName);
return abp.localization.localize.apply(this, copiedArguments);
};
};
abp.localization.isCurrentCulture = function (name) {
return abp.localization.currentCulture
&& abp.localization.currentCulture.name
&& abp.localization.currentCulture.name.indexOf(name) == 0;
};
abp.localization.defaultSourceName = undefined;
abp.localization.abpWeb = abp.localization.getSource('AbpWeb');
/* AUTHORIZATION **********************************************/
//Implements Authorization API that simplifies usage of authorization scripts generated by Abp.
abp.auth = abp.auth || {};
abp.auth.allPermissions = abp.auth.allPermissions || {};
abp.auth.grantedPermissions = abp.auth.grantedPermissions || {};
//Deprecated. Use abp.auth.isGranted instead.
abp.auth.hasPermission = function (permissionName) {
return abp.auth.isGranted.apply(this, arguments);
};
//Deprecated. Use abp.auth.isAnyGranted instead.
abp.auth.hasAnyOfPermissions = function () {
return abp.auth.isAnyGranted.apply(this, arguments);
};
//Deprecated. Use abp.auth.areAllGranted instead.
abp.auth.hasAllOfPermissions = function () {
return abp.auth.areAllGranted.apply(this, arguments);
};
abp.auth.isGranted = function (permissionName) {
return abp.auth.allPermissions[permissionName] != undefined &&
abp.auth.grantedPermissions[permissionName] != undefined;
};
abp.auth.isAnyGranted = function () {
if (!arguments || arguments.length <= 0) {
return true;
}
for (var i = 0; i < arguments.length; i++) {
if (abp.auth.isGranted(arguments[i])) {
return true;
}
}
return false;
};
abp.auth.areAllGranted = function () {
if (!arguments || arguments.length <= 0) {
return true;
}
for (var i = 0; i < arguments.length; i++) {
if (!abp.auth.isGranted(arguments[i])) {
return false;
}
}
return true;
};
abp.auth.tokenCookieName = 'Abp.AuthToken';
abp.auth.setToken = function (authToken, expireDate) {
abp.utils.setCookieValue(abp.auth.tokenCookieName, authToken, expireDate, abp.appPath, abp.domain);
};
abp.auth.getToken = function () {
return abp.utils.getCookieValue(abp.auth.tokenCookieName);
};
abp.auth.clearToken = function () {
abp.auth.setToken();
};
abp.auth.refreshTokenCookieName = 'Abp.AuthRefreshToken';
abp.auth.setRefreshToken = function (refreshToken, expireDate) {
abp.utils.setCookieValue(abp.auth.refreshTokenCookieName, refreshToken, expireDate, abp.appPath, abp.domain);
};
abp.auth.getRefreshToken = function () {
return abp.utils.getCookieValue(abp.auth.refreshTokenCookieName);
};
abp.auth.clearRefreshToken = function () {
abp.auth.setRefreshToken();
};
/* FEATURE SYSTEM *********************************************/
//Implements Features API that simplifies usage of feature scripts generated by Abp.
abp.features = abp.features || {};
abp.features.allFeatures = abp.features.allFeatures || {};
abp.features.get = function (name) {
return abp.features.allFeatures[name];
}
abp.features.getValue = function (name) {
var feature = abp.features.get(name);
if (feature == undefined) {
return undefined;
}
return feature.value;
}
abp.features.isEnabled = function (name) {
var value = abp.features.getValue(name);
return value == 'true' || value == 'True';
}
/* SETTINGS **************************************************/
//Implements Settings API that simplifies usage of setting scripts generated by Abp.
abp.setting = abp.setting || {};
abp.setting.values = abp.setting.values || {};
abp.setting.get = function (name) {
return abp.setting.values[name];
};
abp.setting.getBoolean = function (name) {
var value = abp.setting.get(name);
return value == 'true' || value == 'True';
};
abp.setting.getInt = function (name) {
return parseInt(abp.setting.values[name]);
};
/* REALTIME NOTIFICATIONS ************************************/
abp.notifications = abp.notifications || {};
abp.notifications.severity = {
INFO: 0,
SUCCESS: 1,
WARN: 2,
ERROR: 3,
FATAL: 4
};
abp.notifications.userNotificationState = {
UNREAD: 0,
READ: 1
};
abp.notifications.getUserNotificationStateAsString = function (userNotificationState) {
switch (userNotificationState) {
case abp.notifications.userNotificationState.READ:
return 'READ';
case abp.notifications.userNotificationState.UNREAD:
return 'UNREAD';
default:
abp.log.warn('Unknown user notification state value: ' + userNotificationState)
return '?';
}
};
abp.notifications.getUiNotifyFuncBySeverity = function (severity) {
switch (severity) {
case abp.notifications.severity.SUCCESS:
return abp.notify.success;
case abp.notifications.severity.WARN:
return abp.notify.warn;
case abp.notifications.severity.ERROR:
return abp.notify.error;
case abp.notifications.severity.FATAL:
return abp.notify.error;
case abp.notifications.severity.INFO:
default:
return abp.notify.info;
}
};
abp.notifications.messageFormatters = {};
abp.notifications.messageFormatters['Abp.Notifications.MessageNotificationData'] = function (userNotification) {
return userNotification.notification.data.message || userNotification.notification.data.properties.Message;
};
abp.notifications.messageFormatters['Abp.Notifications.LocalizableMessageNotificationData'] =
function (userNotification) {
var message = userNotification.notification.data.message ||
userNotification.notification.data.properties.Message;
var localizedMessage = abp.localization.localize(
message.name,
message.sourceName
);
if (userNotification.notification.data.properties) {
var properties = Object.keys(userNotification.notification.data.properties);
for (var i = 0; i < properties.length; i++) {
localizedMessage = localizedMessage.replace('{' + properties[i] + '}', userNotification.notification.data.properties[properties[i]]);
}
}
return localizedMessage;
};
abp.notifications.getFormattedMessageFromUserNotification = function (userNotification) {
var formatter = abp.notifications.messageFormatters[userNotification.notification.data.type];
if (!formatter) {
abp.log.warn('No message formatter defined for given data type: ' + userNotification.notification.data.type)
return '?';
}
if (!abp.utils.isFunction(formatter)) {
abp.log.warn('Message formatter should be a function! It is invalid for data type: ' + userNotification.notification.data.type)
return '?';
}
return formatter(userNotification);
}
abp.notifications.showUiNotifyForUserNotification = function (userNotification, options) {
var message = abp.notifications.getFormattedMessageFromUserNotification(userNotification);
var uiNotifyFunc = abp.notifications.getUiNotifyFuncBySeverity(userNotification.notification.severity);
uiNotifyFunc(message, undefined, options);
}
/* LOGGING ***************************************************/
//Implements Logging API that provides secure & controlled usage of console.log
abp.log = abp.log || {};
abp.log.levels = {
DEBUG: 1,
INFO: 2,
WARN: 3,
ERROR: 4,
FATAL: 5
};
abp.log.level = abp.log.levels.DEBUG;
abp.log.log = function (logObject, logLevel) {
if (!window.console || !window.console.log) {
return;
}
if (logLevel != undefined && logLevel < abp.log.level) {
return;
}
console.log(logObject);
};
abp.log.debug = function (logObject) {
abp.log.log("DEBUG: ", abp.log.levels.DEBUG);
abp.log.log(logObject, abp.log.levels.DEBUG);
};
abp.log.info = function (logObject) {
abp.log.log("INFO: ", abp.log.levels.INFO);
abp.log.log(logObject, abp.log.levels.INFO);
};
abp.log.warn = function (logObject) {
abp.log.log("WARN: ", abp.log.levels.WARN);
abp.log.log(logObject, abp.log.levels.WARN);
};
abp.log.error = function (logObject) {
abp.log.log("ERROR: ", abp.log.levels.ERROR);
abp.log.log(logObject, abp.log.levels.ERROR);
};
abp.log.fatal = function (logObject) {
abp.log.log("FATAL: ", abp.log.levels.FATAL);
abp.log.log(logObject, abp.log.levels.FATAL);
};
/* NOTIFICATION *********************************************/
//Defines Notification API, not implements it
abp.notify = abp.notify || {};
abp.notify.success = function (message, title, options) {
abp.log.warn('abp.notify.success is not implemented!');
};
abp.notify.info = function (message, title, options) {
abp.log.warn('abp.notify.info is not implemented!');
};
abp.notify.warn = function (message, title, options) {
abp.log.warn('abp.notify.warn is not implemented!');
};
abp.notify.error = function (message, title, options) {
abp.log.warn('abp.notify.error is not implemented!');
};
/* MESSAGE **************************************************/
//Defines Message API, not implements it
abp.message = abp.message || {};
var showMessage = function (message, title, options) {
alert((title || '') + ' ' + message);
};
abp.message.info = function (message, title, options) {
abp.log.warn('abp.message.info is not implemented!');
return showMessage(message, title, options);
};
abp.message.success = function (message, title, options) {
abp.log.warn('abp.message.success is not implemented!');
return showMessage(message, title, options);
};
abp.message.warn = function (message, title, options) {
abp.log.warn('abp.message.warn is not implemented!');
return showMessage(message, title, options);
};
abp.message.error = function (message, title, options) {
abp.log.warn('abp.message.error is not implemented!');
return showMessage(message, title, options);
};
abp.message.confirm = function (message, title, callback, options) {
abp.log.warn('abp.message.confirm is not implemented!');
var result = confirm(message);
callback && callback(result);
};
/* UI *******************************************************/
abp.ui = abp.ui || {};
/* UI BLOCK */
//Defines UI Block API, not implements it
abp.ui.block = function (elm) {
abp.log.warn('abp.ui.block is not implemented!');
};
abp.ui.unblock = function (elm) {
abp.log.warn('abp.ui.unblock is not implemented!');
};
/* UI BUSY */
//Defines UI Busy API, not implements it
abp.ui.setBusy = function (elm, optionsOrPromise) {
abp.log.warn('abp.ui.setBusy is not implemented!');
};
abp.ui.clearBusy = function (elm) {
abp.log.warn('abp.ui.clearBusy is not implemented!');
};
/* SIMPLE EVENT BUS *****************************************/
abp.event = (function () {
var _callbacks = {};
var on = function (eventName, callback) {
if (!_callbacks[eventName]) {
_callbacks[eventName] = [];
}
_callbacks[eventName].push(callback);
};
var off = function (eventName, callback) {
var callbacks = _callbacks[eventName];
if (!callbacks) {
return;
}
var index = -1;
for (var i = 0; i < callbacks.length; i++) {
if (callbacks[i] === callback) {
index = i;
break;
}
}
if (index < 0) {
return;
}
_callbacks[eventName].splice(index, 1);
};
var trigger = function (eventName) {
var callbacks = _callbacks[eventName];
if (!callbacks || !callbacks.length) {
return;
}
var args = Array.prototype.slice.call(arguments, 1);
for (var i = 0; i < callbacks.length; i++) {
callbacks[i].apply(this, args);
}
};
// Public interface ///////////////////////////////////////////////////
return {
on: on,
off: off,
trigger: trigger
};
})();
/* UTILS ***************************************************/
abp.utils = abp.utils || {};
/* Creates a name namespace.
* Example:
* var taskService = abp.utils.createNamespace(abp, 'services.task');
* taskService will be equal to abp.services.task
* first argument (root) must be defined first
************************************************************/
abp.utils.createNamespace = function (root, ns) {
var parts = ns.split('.');
for (var i = 0; i < parts.length; i++) {
if (typeof root[parts[i]] == 'undefined') {
root[parts[i]] = {};
}
root = root[parts[i]];
}
return root;
};
/* Find and replaces a string (search) to another string (replacement) in
* given string (str).
* Example:
* abp.utils.replaceAll('This is a test string', 'is', 'X') = 'ThX X a test string'
************************************************************/
abp.utils.replaceAll = function (str, search, replacement) {
var fix = search.replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
return str.replace(new RegExp(fix, 'g'), replacement);
};
/* Formats a string just like string.format in C#.
* Example:
* abp.utils.formatString('Hello {0}','Tuana') = 'Hello Tuana'
************************************************************/
abp.utils.formatString = function () {
if (arguments.length < 1) {
return null;
}
var str = arguments[0];
for (var i = 1; i < arguments.length; i++) {
var placeHolder = '{' + (i - 1) + '}';
str = abp.utils.replaceAll(str, placeHolder, arguments[i]);
}
return str;
};
abp.utils.toPascalCase = function (str) {
if (!str || !str.length) {
return str;
}
if (str.length === 1) {
return str.charAt(0).toUpperCase();
}
return str.charAt(0).toUpperCase() + str.substr(1);
}
abp.utils.toCamelCase = function (str) {
if (!str || !str.length) {
return str;
}
if (str.length === 1) {
return str.charAt(0).toLowerCase();
}
return str.charAt(0).toLowerCase() + str.substr(1);
}
abp.utils.truncateString = function (str, maxLength) {
if (!str || !str.length || str.length <= maxLength) {
return str;
}
return str.substr(0, maxLength);
};
abp.utils.truncateStringWithPostfix = function (str, maxLength, postfix) {
postfix = postfix || '...';
if (!str || !str.length || str.length <= maxLength) {
return str;
}
if (maxLength <= postfix.length) {
return postfix.substr(0, maxLength);
}
return str.substr(0, maxLength - postfix.length) + postfix;
};
abp.utils.isFunction = function (obj) {
return !!(obj && obj.constructor && obj.call && obj.apply);
};
/**
* parameterInfos should be an array of { name, value } objects
* where name is query string parameter name and value is it's value.
* includeQuestionMark is true by default.
*/
abp.utils.buildQueryString = function (parameterInfos, includeQuestionMark) {
if (includeQuestionMark === undefined) {
includeQuestionMark = true;
}
var qs = '';
function addSeperator() {
if (!qs.length) {
if (includeQuestionMark) {
qs = qs + '?';
}
} else {
qs = qs + '&';
}
}
for (var i = 0; i < parameterInfos.length; ++i) {
var parameterInfo = parameterInfos[i];
if (parameterInfo.value === undefined) {
continue;
}
if (parameterInfo.value === null) {
parameterInfo.value = '';
}
addSeperator();
if (parameterInfo.value.toJSON && typeof parameterInfo.value.toJSON === "function") {
qs = qs + parameterInfo.name + '=' + encodeURIComponent(parameterInfo.value.toJSON());
} else if (Array.isArray(parameterInfo.value) && parameterInfo.value.length) {
for (var j = 0; j < parameterInfo.value.length; j++) {
if (j > 0) {
addSeperator();
}
qs = qs + parameterInfo.name + '[' + j + ']=' + encodeURIComponent(parameterInfo.value[j]);
}
} else {
qs = qs + parameterInfo.name + '=' + encodeURIComponent(parameterInfo.value);
}
}
return qs;
}
/**
* Sets a cookie value for given key.
* This is a simple implementation created to be used by ABP.
* Please use a complete cookie library if you need.
* @param {string} key
* @param {string} value
* @param {Date} expireDate (optional). If not specified the cookie will expire at the end of session.
* @param {string} path (optional)
*/
abp.utils.setCookieValue = function (key, value, expireDate, path, domain) {
var cookieValue = encodeURIComponent(key) + '=';
if (value) {
cookieValue = cookieValue + encodeURIComponent(value);
}
if (expireDate) {
cookieValue = cookieValue + "; expires=" + expireDate.toUTCString();
}
if (path) {
cookieValue = cookieValue + "; path=" + path;
}
if (domain) {
cookieValue = cookieValue + "; domain=" + domain;
}
document.cookie = cookieValue;
};
/**
* Gets a cookie with given key.
* This is a simple implementation created to be used by ABP.
* Please use a complete cookie library if you need.
* @param {string} key
* @returns {string} Cookie value or null
*/
abp.utils.getCookieValue = function (key) {
var equalities = document.cookie.split('; ');
for (var i = 0; i < equalities.length; i++) {
if (!equalities[i]) {
continue;
}
var splitted = equalities[i].split('=');
if (splitted.length != 2) {
continue;
}
if (decodeURIComponent(splitted[0]) === key) {
return decodeURIComponent(splitted[1] || '');
}
}
return null;
};
/**
* Deletes cookie for given key.
* This is a simple implementation created to be used by ABP.
* Please use a complete cookie library if you need.
* @param {string} key
* @param {string} path (optional)
*/
abp.utils.deleteCookie = function (key, path) {
var cookieValue = encodeURIComponent(key) + '=';
cookieValue = cookieValue + "; expires=" + (new Date(new Date().getTime() - 86400000)).toUTCString();
if (path) {
cookieValue = cookieValue + "; path=" + path;
}
document.cookie = cookieValue;
}
/**
* Gets the domain of given url
* @param {string} url
* @returns {string}
*/
abp.utils.getDomain = function (url) {
var domainRegex = /(https?:){0,1}\/\/((?:[\w\d-]+\.)+[\w\d]{2,})/i;
var matches = domainRegex.exec(url);
return (matches && matches[2]) ? matches[2] : '';
}
/* TIMING *****************************************/
abp.timing = abp.timing || {};
abp.timing.utcClockProvider = (function () {
var toUtc = function (date) {
return Date.UTC(
date.getUTCFullYear(), date.getUTCMonth(), date.getUTCDate(), date.getUTCHours(), date.getUTCMinutes(), date.getUTCSeconds(), date.getUTCMilliseconds()
);
}
var now = function () {
return toUtc(new Date());
};
var normalize = function (date) {
if (!date) {
return date;
}
return new Date(toUtc(date));
};
// Public interface ///////////////////////////////////////////////////
return {
now: now,
normalize: normalize,
supportsMultipleTimezone: true
};
})();
abp.timing.localClockProvider = (function () {
var toLocal = function (date) {
return new Date(
date.getFullYear(), date.getMonth(), date.getDate(), date.getHours(), date.getMinutes(), date.getSeconds(), date.getMilliseconds()
);
}
var now = function () {
return toLocal(new Date());
}
var normalize = function (date) {
if (!date) {
return date;
}
return toLocal(date);
}
// Public interface ///////////////////////////////////////////////////
return {
now: now,
normalize: normalize,
supportsMultipleTimezone: false
};
})();
abp.timing.unspecifiedClockProvider = (function () {
var now = function () {
return new Date();
}
var normalize = function (date) {
return date;
}
// Public interface ///////////////////////////////////////////////////
return {
now: now,
normalize: normalize,
supportsMultipleTimezone: false
};
})();
abp.timing.convertToUserTimezone = function (date) {
var localTime = date.getTime();
var utcTime = localTime + (date.getTimezoneOffset() * 60000);
var targetTime = parseInt(utcTime) + parseInt(abp.timing.timeZoneInfo.windows.currentUtcOffsetInMilliseconds);
return new Date(targetTime);
};
/* CLOCK *****************************************/
abp.clock = abp.clock || {};
abp.clock.now = function () {
if (abp.clock.provider) {
return abp.clock.provider.now();
}
return new Date();
}
abp.clock.normalize = function (date) {
if (abp.clock.provider) {
return abp.clock.provider.normalize(date);
}
return date;
}
abp.clock.provider = abp.timing.unspecifiedClockProvider;
/* SECURITY ***************************************/
abp.security = abp.security || {};
abp.security.antiForgery = abp.security.antiForgery || {};
abp.security.antiForgery.tokenCookieName = 'XSRF-TOKEN';
abp.security.antiForgery.tokenHeaderName = 'X-XSRF-TOKEN';
abp.security.antiForgery.getToken = function () {
return abp.utils.getCookieValue(abp.security.antiForgery.tokenCookieName);
};
abp.security.antiForgery.shouldSendToken = function (settings) {
if (settings.crossDomain === undefined || settings.crossDomain === null) {
return abp.utils.getDomain(location.href) === abp.utils.getDomain(settings.url);
}
return !settings.crossDomain;
};
})();

4
src/index.html

@ -2,7 +2,7 @@
<html lang="zh-CN">
<head>
<meta charset="utf-8">
<title>石化加油站</title>
<title>化石油智能安全管理系统</title>
<base href="/">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="icon" type="image/x-icon" href="favicon.ico">
@ -10,5 +10,5 @@
<body>
<app-root></app-root>
</body>
<script src="./assets/js/abp.js"></script>
</html>

Loading…
Cancel
Save