UI: Override parse function of datatimeAdapter
This commit is contained in:
parent
abbf791987
commit
080c9b5856
37
ui-ngx/src/app/shared/adapter/custom-datatime-adapter.ts
Normal file
37
ui-ngx/src/app/shared/adapter/custom-datatime-adapter.ts
Normal file
@ -0,0 +1,37 @@
|
||||
///
|
||||
/// Copyright © 2016-2022 The Thingsboard Authors
|
||||
///
|
||||
/// 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.
|
||||
///
|
||||
|
||||
import { Injectable } from '@angular/core';
|
||||
import { NativeDatetimeAdapter } from '@mat-datetimepicker/core';
|
||||
|
||||
|
||||
@Injectable()
|
||||
export class CustomDateAdapter extends NativeDatetimeAdapter {
|
||||
|
||||
parse(value: string, parseFormat: any): any {
|
||||
if (typeof value === 'number') {
|
||||
return new Date(value);
|
||||
}
|
||||
let newDate = null;
|
||||
const formatToParts = Intl.DateTimeFormat(this.locale).formatToParts();
|
||||
if (formatToParts[0].type.toLowerCase() === 'day') {
|
||||
const literal = formatToParts[1].value;
|
||||
newDate = value.replace(new RegExp(`(\\d+[${literal}])(\\d+[${literal}])`), '$2$1');
|
||||
}
|
||||
return value ? new Date(Date.parse(newDate || value)) : null;
|
||||
}
|
||||
|
||||
}
|
||||
@ -53,7 +53,7 @@ import { MatTabsModule } from '@angular/material/tabs';
|
||||
import { MatToolbarModule } from '@angular/material/toolbar';
|
||||
import { MatTooltipModule } from '@angular/material/tooltip';
|
||||
import { MatListModule } from '@angular/material/list';
|
||||
import { MatDatetimepickerModule, MatNativeDatetimeModule } from '@mat-datetimepicker/core';
|
||||
import { DatetimeAdapter, MatDatetimepickerModule, MatNativeDatetimeModule } from '@mat-datetimepicker/core';
|
||||
import { NgxDaterangepickerMd } from 'ngx-daterangepicker-material';
|
||||
import { GridsterModule } from 'angular-gridster2';
|
||||
import { FlexLayoutModule } from '@angular/flex-layout';
|
||||
@ -165,6 +165,7 @@ import { DragDropModule } from '@angular/cdk/drag-drop';
|
||||
import { MultipleImageInputComponent } from '@shared/components/multiple-image-input.component';
|
||||
import { BranchAutocompleteComponent } from '@shared/components/vc/branch-autocomplete.component';
|
||||
import { PhoneInputComponent } from '@shared/components/phone-input.component';
|
||||
import { CustomDateAdapter } from '@shared/adapter/custom-datatime-adapter';
|
||||
|
||||
export function MarkedOptionsFactory(markedOptionsService: MarkedOptionsService) {
|
||||
return markedOptionsService;
|
||||
@ -188,6 +189,7 @@ export function MarkedOptionsFactory(markedOptionsService: MarkedOptionsService)
|
||||
provide: MAT_DATE_LOCALE,
|
||||
useValue: 'en-GB'
|
||||
},
|
||||
{ provide: DatetimeAdapter, useClass: CustomDateAdapter },
|
||||
{ provide: HELP_MARKDOWN_COMPONENT_TOKEN, useValue: HelpMarkdownComponent },
|
||||
{ provide: SHARED_MODULE_TOKEN, useValue: SharedModule },
|
||||
TbPopoverService
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user