{"id":28026030,"url":"https://github.com/codercatdev/angularfire2-env-issue","last_synced_at":"2025-05-11T04:55:50.208Z","repository":{"id":55881631,"uuid":"107436323","full_name":"codercatdev/angularfire2-env-issue","owner":"codercatdev","description":"Issue with using the default enviornment","archived":false,"fork":false,"pushed_at":"2020-12-09T19:17:12.000Z","size":65,"stargazers_count":3,"open_issues_count":1,"forks_count":1,"subscribers_count":0,"default_branch":"master","last_synced_at":"2025-05-11T04:55:40.412Z","etag":null,"topics":[],"latest_commit_sha":null,"homepage":null,"language":"TypeScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/codercatdev.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null}},"created_at":"2017-10-18T16:46:02.000Z","updated_at":"2020-12-09T19:17:14.000Z","dependencies_parsed_at":"2022-08-15T08:31:14.668Z","dependency_job_id":null,"html_url":"https://github.com/codercatdev/angularfire2-env-issue","commit_stats":null,"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/codercatdev%2Fangularfire2-env-issue","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/codercatdev%2Fangularfire2-env-issue/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/codercatdev%2Fangularfire2-env-issue/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/codercatdev%2Fangularfire2-env-issue/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/codercatdev","download_url":"https://codeload.github.com/codercatdev/angularfire2-env-issue/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":253518960,"owners_count":21921082,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":[],"created_at":"2025-05-11T04:55:49.596Z","updated_at":"2025-05-11T04:55:50.172Z","avatar_url":"https://github.com/codercatdev.png","language":"TypeScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"# What is this repo used for?\nThis shows how to use ionic framework with @ionic/app-scripts@3.0.0 to allow building of any environment file.\n\nThe original solution (but this doesn't work with AOT compiler)\nhttps://github.com/gshigeto/ionic-environment-variables\n\nIssue 1205 in ionic-cli\nhttps://github.com/ionic-team/ionic-cli/issues/1205\n\nAlso referenced in Issue 1006 for ionic-app-scripts\nhttps://github.com/ionic-team/ionic-app-scripts/issues/1006\n\n# Clone\n```\ngit clone \u003cthis repo\u003e\n```\n\n# Firebase testing\n\nMake sure you have firebase CLI installed\nnpm install -g firebase-tools\n\n```\nnpm install\n```\n\n## Dev\n```\nnpm run build ionic:build:dev:prod\n\nfirebase serve\n```\n\nGo to localhost:5000\n-\u003e should log you into environment-sample-dev.firebaseapp.com\n\n## Prod\n```\nnpm run build ionic:build:prod:prod\n\nfirebase serve\n```\n\nGo to localhost:5000\n-\u003e should log you into environment-sample-prod.firebaseapp.com\n\n## Ionic Serve\nstandard ionic serve will run on 8100(or next available) and pickup your env/environment.dev.json file\n\n# Key files\n## package.json\n```\n  \"scripts\": {\n    \"clean\": \"ionic-app-scripts clean\",\n    \"build\": \"ionic-app-scripts build\",\n    \"lint\": \"ionic-app-scripts lint\",\n    \"ionic:build\": \"ionic-app-scripts build\",\n    \"ionic:serve\": \"ionic-app-scripts serve\",\n    \"ionic:build:dev\": \"cross-env MY_ENV=dev ionic-app-scripts build\",\n    \"ionic:build:dev:prod\": \"cross-env MY_ENV=dev ionic-app-scripts build --prod\",\n    \"ionic:build:prod:prod\": \"cross-env MY_ENV=prod ionic-app-scripts build --prod\"\n  },\n  \"config\": {\n    \"ionic_copy\": \"./config/copy.config.js\",\n    \"ionic_webpack\": \"./config/webpack.config.js\"\n  },\n```\n## config/copy.config.js\n```\nvar fs = require('fs');\nvar path = require('path');\nvar useDefaultConfig = require('@ionic/app-scripts/config/copy.config.js');\n\nmodule.exports = function () {\n\tvar fs = require('fs');\n\tvar path = require('path');\n\n\tvar ROOT_DIR = process.cwd();\n\tvar DEST_FILE = 'src/environments/environment.json';\n\n\tvar env = process.env.MY_ENV || 'dev';\n\tvar envFile = 'env/environment.' + env + '.json';\n\t\n\tvar configFileFull = path.join(ROOT_DIR, envFile);\n\tvar destFileFull = path.join(ROOT_DIR, DEST_FILE);\n\t\n\tvar data = fs.readFileSync(configFileFull, 'utf8');\n\n\tfs.writeFileSync(destFileFull, data);\n\n\treturn useDefaultConfig;\n};\n```\n## config/webpack.config.js\n```\nvar path = require('path');\nvar useDefaultConfig = require('@ionic/app-scripts/config/webpack.config.js');\n\nmodule.exports = function () {\n\tvar envFile = './src/environments/environment.ts';\n\tvar alias = { '@app/env': path.resolve(envFile) };\n\n\tuseDefaultConfig.dev.resolve.alias = alias;\n\tuseDefaultConfig.prod.resolve.alias = alias;\n\n\treturn useDefaultConfig;\n};\n```\n## environments\n### env/environment.dev.json\nThis is your dev config\n```\n{\n    \"environmentName\": \"Development Environment\",\n    \"ionicEnvName\": \"dev\",\n    \"firebase\": {\n        \"apiKey\": \"AIzaSyABYjyKLf1Q4YWpr-IeVlqY8SvT9GBfR_k\",\n        \"authDomain\": \"environment-sample-dev.firebaseapp.com\",\n        \"projectId\": \"environment-sample-dev\"\n    }\n}\n```\n### env/environment.prod.json\nThis is your prod config\n```\n{\n    \"environmentName\": \"Production Environment\",\n    \"ionicEnvName\": \"prod\",\n    \"firebase\": {\n        \"apiKey\": \"AIzaSyBX7fxtorP7FpATNUy3oyIBtQ5NdhYhfnc\",\n        \"authDomain\": \"environment-sample-prod.firebaseapp.com\",\n        \"projectId\": \"environment-sample-prod\"\n    }\n}\n```\n## src/app/app.d.ts\nThis allows the use of json files\n```\ndeclare module '*.json' {\n    const value: any;\n    export default value;\n}\n```\n\n## src/environments/environment.ts\nAllow typescript to the configs\n```\nimport { Environment } from './environment.model';\nimport * as data from './environment.json';\n\nexport const ENV: Environment = \u003cany\u003edata;\n```\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fcodercatdev%2Fangularfire2-env-issue","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fcodercatdev%2Fangularfire2-env-issue","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fcodercatdev%2Fangularfire2-env-issue/lists"}