Не удалось импортировать компонент Kendo TimePicker для Angular 2+
Согласно информационному бюллетеню KendoUI, которое я получил по электронной почте в эту среду (13.09.2017), был выпущен новый TimePicker. Я пытаюсь импортировать компонент TimePicker в свой проект, но я не могу это сделать. В соответствии с API мы находимся на версии 1.2.0 для кендо-угловых дат ввода, которые должны содержать TimePickerModule. Я попытался выполнить установку npm, указав эту версию (1.2.0), и я получаю сообщение об ошибке ниже.
Ошибка fetchPackageMetaData для @progress/kendo-angular-dateinputs@^1.2.0 {Ошибка: совместимая версия не найдена: @ progress / kendo-angular-dateinputs @ ^ 1.0.6
37 silly fetchPackageMetaData Допустимые цели установки:
37 silly fetchPackageMetaData 1.0.5, 1.0.5-dev.201706261326, 1.0.4, 1.0.4-dev.201706150809, 1.0.4-dev.201706131239, 1.0.3, 1.0.3-dev.201706051028, 1.0.2, 1.0.2-dev.201705311506, 1.0.2-dev.201705261318, 1.0.2-dev.201705240946, 1.0.2-dev.201705240940, 1.0.2-dev.201705221449, 1.0.1, 1.0.0, 0.9.0, 0,8,3, 0,8,2, 0,8,1, 0,8,0, 0,7, 0, 0,6,1, 0,6, 0, 0,5,3, 0,5,2, 0,5,1, 0,5, 0, 0,4,1 0,4, 0, 0,3,7, 0,3,6, 0,3,5, 0,3,4, 0,3,3, 0,3,2, 0,3,1, 0,3,0, 0,2,0, 0,1,0
В пакете json я добавил зависимость как "@progress/kendo-angular-dateinputs": "^1.2.0". Я могу получить только последнюю версию 1.0.5, и когда я добавляю теги timepicker с этим в моем html, я получаю сообщения об ошибках:
Uncaught Error: Ошибки синтаксического анализа шаблона: "kendo-timepicker" не является известным элементом: 1. Если "kendo-timepicker" является угловым компонентом, то убедитесь, что он является частью этого модуля. 2. Если 'kendo-timepicker' является веб-компонентом, то добавьте 'CUSTOM_ELEMENTS_SCHEMA' к '@NgModule.schemas' этого компонента, чтобы подавить это сообщение. (" [ОШИБКА ->]
Кто-нибудь может проверить, действительно ли V1.2.0 действительно доступен для людей?
Также копирую пакет json
{
"name": "test-project",
"version": "0.0.0",
"license": "MIT",
"scripts": {
"ng": "ng",
"start": "ng serve",
"build": "ng build",
"test": "ng test",
"lint": "ng lint",
"e2e": "ng e2e"
},
"private": true,
"dependencies": {
"@angular/animations": "^4.0.0",
"@angular/common": "^4.0.0",
"@angular/compiler": "^4.0.0",
"@angular/core": "^4.0.0",
"@angular/forms": "^4.0.0",
"@angular/http": "^4.0.0",
"@angular/platform-browser": "^4.0.0",
"@angular/platform-browser-dynamic": "^4.0.0",
"@angular/router": "^4.0.0",
"@progress/kendo-angular-dateinputs": "^1.2.0",
"@progress/kendo-angular-intl": "^1.2.1",
"@progress/kendo-angular-l10n": "^1.0.2",
"core-js": "^2.4.1",
"rxjs": "^5.4.1",
"zone.js": "^0.8.14"
},
"devDependencies": {
"@angular/cli": "1.2.7",
"@angular/compiler-cli": "^4.0.0",
"@angular/language-service": "^4.0.0",
"@types/jasmine": "~2.5.53",
"@types/jasminewd2": "~2.0.2",
"@types/node": "~6.0.60",
"codelyzer": "~3.0.1",
"jasmine-core": "~2.6.2",
"jasmine-spec-reporter": "~4.1.0",
"karma": "~1.7.0",
"karma-chrome-launcher": "~2.1.1",
"karma-cli": "~1.0.1",
"karma-coverage-istanbul-reporter": "^1.2.1",
"karma-jasmine": "~1.1.0",
"karma-jasmine-html-reporter": "^0.2.2",
"protractor": "~5.1.2",
"ts-node": "~3.0.4",
"tslint": "~5.3.2",
"typescript": "~2.3.3"
}
}
2 ответа
Я заметил, что не могу получать новые обновления через NPM, однако недавно я обнаружил следующее на странице пакетов NPM по адресу http://docs.telerik.com/kendo-ui/intro/installation/npm
Важный
Реестр NPM Progress был удален в пользу npmjs.com. Чтобы начать использовать реестр по умолчанию, удалите две строки, которые содержат registry.npm.telerik.com из вашего файла.npmrc.
Чтобы исправить это, я удалил следующую строку из файла ~/.npmrc
@progress:registry=https://registry.npm.telerik.com/
После этого все новые пакеты доступны
Я установил зависимость в package.json, чтобы "@progress/kendo-angular-dateinputs": "^1.0.5"
и установленная версия @progress/kendo-angular-dropdowns 1.2.0
так что все в порядке.
Вы можете установить программу проверки версии:
npm install -g version-check
затем запустите команду, чтобы увидеть, какая у вас версия:
version-check
Вы импортировали модуль в свой корневой модуль?
import { TimePickerModule } from '@progress/kendo-angular-dateinputs';
@NgModule({
declarations: [HomeComponent],
imports: [
BrowserModule,
ButtonsModule,
TimePickerModule
],
providers: []
})
export class HomeModule { }
в формате HTML:
<kendo-timepicker
[format]="'HH:mm'"
name="workingTimeFrom"
[(ngModel)]="workingDay.startTime"
(valueChange)="updateStartTime(i,$event)">
</kendo-timepicker>