Hi Experts,
My app was running fine till yesterday but all of a sudden it has started giving errors related to Angular Version 5. Looks like Angular 5 is handling FirebaseList/ObjectObservable in different way and in case i want to use it, i will have to make lot of changes in my app. I am currently not interested in doing that. Please suggest the way to get rid of this issue. Here are more details regarding the same:
Error Message:
Typescript Error
Class 'FirebaseApp' incorrectly implements interface 'App'. Property 'firestore' is missing in type 'FirebaseApp'.
node_modules/angularfire2/app/firebase.app.module.d.ts
||export declare const FirebaseAppConfigToken: InjectionToken<FirebaseAppConfig>;|
| --- | --- |
||export declare class FirebaseApp implements firebase.app.App {|
||name: string;|
Typescript Error
Namespace 'firebase' has no exported member 'Promise'.
node_modules/angularfire2/app/firebase.app.module.d.ts
||storage: () => firebase.storage.Storage;|
| --- | --- |
||delete: () => firebase.Promise<any>;|
||}|
Typescript Error
Namespace 'firebase' has no exported member 'Promise'.
node_modules/angularfire2/database/firebase_list_observable.d.ts
||push(val: any): firebase.database.ThenableReference;|
| --- | --- |
||update(item: FirebaseOperation, value: Object): firebase.Promise<void>;|
||remove(item?: FirebaseOperation): firebase.Promise<void>;|
Package.json
{
"name": "****************",
"author": "******************",
"homepage": "*****************",
"private": true,
"scripts": {
"build": "ionic-app-scripts build",
"clean": "ionic-app-scripts clean",
"ionic:build": "ionic-app-scripts build",
"ionic:serve": "ionic-app-scripts serve"
},
"dependencies": {
"@agm/core": "^1.0.0-beta.0",
"@angular/common": "4.1.2",
"@angular/compiler": "4.1.2",
"@angular/compiler-cli": "4.1.2",
"@angular/core": "4.1.2",
"@angular/forms": "4.1.2",
"@angular/http": "4.1.2",
"@angular/platform-browser": "4.1.2",
"@angular/platform-browser-dynamic": "4.1.2",
"@ionic-native/camera": "^4.9.0",
"@ionic-native/core": "3.10.2",
"@ionic-native/diagnostic": "^3.10.3",
"@ionic-native/facebook": "^3.12.1",
"@ionic-native/firebase": "^4.2.1",
"@ionic-native/geolocation": "^3.5.0",
"@ionic-native/google-plus": "^3.12.1",
"@ionic-native/image-picker": "^4.1.0",
"@ionic-native/in-app-browser": "^4.1.0",
"@ionic-native/social-sharing": "^4.1.0",
"@ionic-native/spinner-dialog": "^4.1.0",
"@ionic-native/status-bar": "3.6.1",
"@ionic/storage": "2.0.1",
"angular2-google-maps": "^0.17.0",
"angular2-moment": "^1.3.3",
"angularfire2": "^4.0.0-rc0",
"chart.js": "^2.7.2",
"cordova-android": "^6.2.3",
"cordova-browser": "^4.1.0",
"cordova-ios": "^4.4.0",
"cordova-plugin-camera": "^2.4.1",
"cordova-plugin-cocoapod-support": "^1.3.0",
"cordova-plugin-compat": "^1.1.0",
"cordova-plugin-console": "^1.0.7",
"cordova-plugin-device": "^1.1.6",
"cordova-plugin-facebook4": "^1.9.1",
"cordova-plugin-firebase": "git+https://github.com/arnesson/cordova-plugin-firebase.git",
"cordova-plugin-geolocation": "^2.4.3",
"cordova-plugin-googleplus": "^5.1.1",
"cordova-plugin-keyboard": "^1.1.5",
"cordova-plugin-native-spinner": "^1.1.3",
"cordova-plugin-nativestorage": "^2.2.2",
"cordova-plugin-spinner-dialog": "^1.3.1",
"cordova-plugin-splashscreen": "^4.0.3",
"cordova-plugin-statusbar": "^2.2.3",
"cordova-plugin-telerik-imagepicker": "^2.1.8",
"cordova-plugin-whitelist": "^1.3.2",
"cordova-plugin-wkwebview-engine": "git+https://github.com/ionic-team/cordova-plugin-wkwebview-engine.git",
"cordova-plugin-x-socialsharing": "^5.2.0",
"cordova-sqlite-storage": "^2.0.4",
"cordova.plugins.diagnostic": "^3.6.6",
"date-fns": "^1.28.5",
"es6-promise-plugin": "^4.1.0",
"firebase": "^4.2.0",
"font-awesome": "^4.7.0",
"ionic-angular": "^3.5.3-201707261447",
"ionic-native": "^2.9.0",
"ionic-plugin-keyboard": "^2.2.1",
"ionic2-rating": "^1.2.2",
"ionicons": "3.0.0",
"moment": "^2.17.1",
"promise-polyfill": "6.0.2",
"run": "^1.4.0",
"rxjs": "5.1.1",
"sw-toolbox": "3.6.0",
"underscore": "^1.9.1",
"zone.js": "0.8.11"
},
"devDependencies": {
"@ionic-native/splash-screen": "^4.1.0",
"@ionic/app-scripts": "^2.1.0-201707262225",
"ionic": "3.20.0",
"typescript": "2.3.3"
},
"config": {
"ionic_copy": "./scripts/copy.config.js"
},
"description": "mappskool: A school's quick guide to a delighted parent.",
"cordova": {
"plugins": {
"cordova-plugin-googleplus": {
"REVERSED_CLIENT_ID": "com.googleusercontent.apps.447445878863-l7686320qmljoqjira74a5vci3jk7opl"
},
"cordova-plugin-console": {},
"cordova-plugin-device": {},
"cordova-plugin-splashscreen": {},
"cordova-plugin-statusbar": {},
"ionic-plugin-keyboard": {},
"cordova-plugin-facebook4": {
"APP_ID": "1789216028035253",
"APP_NAME": "mAppSkool"
},
"cordova-plugin-compat": {},
"cordova-plugin-geolocation": {},
"cordova-plugin-keyboard": {},
"cordova-plugin-nativestorage": {},
"cordova-sqlite-storage": {},
"cordova.plugins.diagnostic": {},
"cordova-plugin-camera": {
"CAMERA_USAGE_DESCRIPTION": " ",
"PHOTOLIBRARY_USAGE_DESCRIPTION": " "
},
"cordova-plugin-native-spinner": {},
"cordova-plugin-spinner-dialog": {},
"com.synconset.imagepicker": {
"PHOTO_LIBRARY_USAGE_DESCRIPTION": "mAppSkool Photo Library"
},
"cordova-plugin-wkwebview-engine": {},
"cordova-plugin-x-socialsharing": {},
"cordova-plugin-whitelist": {},
"cordova-plugin-firebase": {}
},
"platforms": [
"android",
"browser",
"ios"
]
}
}
Config.xml
<?xml version='1.0' encoding='utf-8'?>
<widget id="*******************" version="0.0.8" xmlns="http://www.w3.org/ns/widgets" xmlns:cdv="http://cordova.apache.org/ns/1.0">
<name>********************</name>
<description>*********************************</description>
<author email="****************" href="******************">*****************</author>
<content src="index.html" />
<access origin="*" />
<allow-intent href="http://*/*" />
<allow-intent href="https://*/*" />
<allow-intent href="tel:*" />
<allow-intent href="sms:*" />
<allow-intent href="mailto:*" />
<allow-intent href="geo:*" />
<platform name="android">
<allow-intent href="market:*" />
<preference name="loadUrlTimeoutValue" value="700000" />
<icon density="ldpi" src="resources/android/icon/drawable-ldpi-icon.png" />
<icon density="mdpi" src="resources/android/icon/drawable-mdpi-icon.png" />
<icon density="hdpi" src="resources/android/icon/drawable-hdpi-icon.png" />
<icon density="xhdpi" src="resources/android/icon/drawable-xhdpi-icon.png" />
<icon density="xxhdpi" src="resources/android/icon/drawable-xxhdpi-icon.png" />
<icon density="xxxhdpi" src="resources/android/icon/drawable-xxxhdpi-icon.png" />
<splash density="land-ldpi" src="resources/android/splash/drawable-land-ldpi-screen.png" />
<splash density="land-mdpi" src="resources/android/splash/drawable-land-mdpi-screen.png" />
<splash density="land-hdpi" src="resources/android/splash/drawable-land-hdpi-screen.png" />
<splash density="land-xhdpi" src="resources/android/splash/drawable-land-xhdpi-screen.png" />
<splash density="land-xxhdpi" src="resources/android/splash/drawable-land-xxhdpi-screen.png" />
<splash density="land-xxxhdpi" src="resources/android/splash/drawable-land-xxxhdpi-screen.png" />
<splash density="port-ldpi" src="resources/android/splash/drawable-port-ldpi-screen.png" />
<splash density="port-mdpi" src="resources/android/splash/drawable-port-mdpi-screen.png" />
<splash density="port-hdpi" src="resources/android/splash/drawable-port-hdpi-screen.png" />
<splash density="port-xhdpi" src="resources/android/splash/drawable-port-xhdpi-screen.png" />
<splash density="port-xxhdpi" src="resources/android/splash/drawable-port-xxhdpi-screen.png" />
<splash density="port-xxxhdpi" src="resources/android/splash/drawable-port-xxxhdpi-screen.png" />
</platform>
<platform name="ios">
<allow-intent href="itms:*" />
<allow-intent href="itms-apps:*" />
<icon height="57" src="resources/ios/icon/icon.png" width="57" />
<icon height="114" src="resources/ios/icon/icon@2x.png" width="114" />
<icon height="40" src="resources/ios/icon/icon-40.png" width="40" />
<icon height="80" src="resources/ios/icon/icon-40@2x.png" width="80" />
<icon height="120" src="resources/ios/icon/icon-40@3x.png" width="120" />
<icon height="50" src="resources/ios/icon/icon-50.png" width="50" />
<icon height="100" src="resources/ios/icon/icon-50@2x.png" width="100" />
<icon height="60" src="resources/ios/icon/icon-60.png" width="60" />
<icon height="120" src="resources/ios/icon/icon-60@2x.png" width="120" />
<icon height="180" src="resources/ios/icon/icon-60@3x.png" width="180" />
<icon height="72" src="resources/ios/icon/icon-72.png" width="72" />
<icon height="144" src="resources/ios/icon/icon-72@2x.png" width="144" />
<icon height="76" src="resources/ios/icon/icon-76.png" width="76" />
<icon height="152" src="resources/ios/icon/icon-76@2x.png" width="152" />
<icon height="167" src="resources/ios/icon/icon-83.5@2x.png" width="167" />
<icon height="29" src="resources/ios/icon/icon-small.png" width="29" />
<icon height="58" src="resources/ios/icon/icon-small@2x.png" width="58" />
<icon height="87" src="resources/ios/icon/icon-small@3x.png" width="87" />
<splash height="1136" src="resources/ios/splash/Default-568h@2x~iphone.png" width="640" />
<splash height="1334" src="resources/ios/splash/Default-667h.png" width="750" />
<splash height="2208" src="resources/ios/splash/Default-736h.png" width="1242" />
<splash height="1242" src="resources/ios/splash/Default-Landscape-736h.png" width="2208" />
<splash height="1536" src="resources/ios/splash/Default-Landscape@2x~ipad.png" width="2048" />
<splash height="2048" src="resources/ios/splash/Default-Landscape@~ipadpro.png" width="2732" />
<splash height="768" src="resources/ios/splash/Default-Landscape~ipad.png" width="1024" />
<splash height="2048" src="resources/ios/splash/Default-Portrait@2x~ipad.png" width="1536" />
<splash height="2732" src="resources/ios/splash/Default-Portrait@~ipadpro.png" width="2048" />
<splash height="1024" src="resources/ios/splash/Default-Portrait~ipad.png" width="768" />
<splash height="960" src="resources/ios/splash/Default@2x~iphone.png" width="640" />
<splash height="480" src="resources/ios/splash/Default~iphone.png" width="320" />
<preference name="KeychainAccessibility" value="WhenUnlocked" />
<icon height="1024" src="resources/ios/icon/icon-1024.png" width="1024" />
<splash height="2732" src="resources/ios/splash/Default@2x~universal~anyany.png" width="2732" />
</platform>
<platform name="wp8">
<icon height="99" src="resources/wp8/icon/ApplicationIcon.png" width="99" />
<icon height="159" src="resources/wp8/icon/Background.png" width="159" />
<splash height="1280" src="resources/wp8/splash/SplashScreenImage.png" width="768" />
</platform>
<preference name="webviewbounce" value="false" />
<preference name="UIWebViewBounce" value="false" />
<preference name="DisallowOverscroll" value="true" />
<preference name="android-minSdkVersion" value="16" />
<preference name="BackupWebStorage" value="none" />
<preference name="SplashMaintainAspectRatio" value="true" />
<preference name="FadeSplashScreenDuration" value="300" />
<preference name="SplashShowOnlyFirstTime" value="false" />
<preference name="SplashScreen" value="screen" />
<preference name="SplashScreenDelay" value="30000" />
<feature name="StatusBar">
<param name="ios-package" onload="true" value="CDVStatusBar" />
</feature>
<allow-navigation href="http://192.168.1.206:8100" />
<allow-navigation href="http://192.168.0.7:8100" />
<icon src="resources/android/icon/drawable-xhdpi-icon.png" />
<allow-navigation href="http://192.168.225.67:8100" />
<allow-navigation href="http://192.168.56.1:8100" />
<allow-navigation href="http://192.168.0.2:8100" />
<allow-navigation href="http://192.168.0.8:8100" />
<allow-navigation href="http://172.24.19.136:8100" />
<allow-navigation href="http://172.24.19.130:8100" />
<allow-navigation href="http://172.24.19.130:8101" />
<allow-navigation href="http://192.168.0.5:8100" />
<allow-navigation href="http://192.168.0.5:8101" />
<allow-navigation href="http://192.168.0.5:8102" />
<allow-navigation href="http://10.85.229.163:8102" />
<allow-navigation href="http://192.168.0.2:8102" />
<allow-navigation href="http://192.168.0.2:8101" />
<allow-navigation href="http://192.168.1.100:8100" />
<allow-navigation href="http://192.168.1.101:8100" />
<allow-navigation href="http://192.168.1.102:8100" />
<allow-navigation href="http://192.168.1.102:8101" />
<engine name="android" spec="^6.2.3" />
<engine name="browser" spec="^4.1.0" />
<engine name="ios" spec="^4.4.0" />
<plugin name="com.synconset.imagepicker">
<variable name="PHOTO_LIBRARY_USAGE_DESCRIPTION" value="mAppSkool Photo Library" />
</plugin>
<plugin name="cordova-plugin-compat" spec="^1.1.0" />
<plugin name="cordova-plugin-console" spec="^1.0.7" />
<plugin name="cordova-plugin-device" spec="^1.1.6" />
<plugin name="cordova-plugin-facebook4" spec="^1.9.1">
<variable name="APP_ID" value="1789216028035253" />
<variable name="APP_NAME" value="mAppSkool" />
</plugin>
<plugin name="cordova-plugin-firebase" spec="git+https://github.com/arnesson/cordova-plugin-firebase.git" />
<plugin name="cordova-plugin-geolocation" spec="^2.4.3" />
<plugin name="cordova-plugin-googleplus" spec="^5.1.1">
<variable name="REVERSED_CLIENT_ID" value="com.googleusercontent.apps.447445878863-l7686320qmljoqjira74a5vci3jk7opl" />
</plugin>
<plugin name="cordova-plugin-keyboard" spec="^1.1.5" />
<plugin name="cordova-plugin-native-spinner" spec="^1.1.3" />
<plugin name="cordova-plugin-nativestorage" spec="^2.2.2" />
<plugin name="cordova-plugin-spinner-dialog" spec="^1.3.1" />
<plugin name="cordova-plugin-splashscreen" spec="^4.0.3" />
<plugin name="cordova-plugin-statusbar" spec="^2.2.3" />
<plugin name="cordova-plugin-whitelist" spec="^1.3.2" />
<plugin name="cordova-plugin-wkwebview-engine" spec="git+https://github.com/ionic-team/cordova-plugin-wkwebview-engine.git" />
<plugin name="cordova-plugin-x-socialsharing" spec="^5.2.0" />
<plugin name="cordova-sqlite-storage" spec="^2.0.4" />
<plugin name="cordova.plugins.diagnostic" spec="^3.6.6" />
<plugin name="ionic-plugin-keyboard" spec="^2.2.1" />
<plugin name="cordova-plugin-camera" spec="^2.4.1">
<variable name="CAMERA_USAGE_DESCRIPTION" value=" " />
<variable name="PHOTOLIBRARY_USAGE_DESCRIPTION" value=" " />
</plugin>
</widget>
Please help.