How to inject extra HTML to index.html during Angular production build before its hash for ngsw.json is...

Multi tool use
I need to inject this tag into a location in the compiled index.html
after running ng build --prod
.
<script>const VERSION = '1.0.0-{someCompileTimeValue}';</script>
Normally, after building, i would use gulp-inject
to inject that tag (including other things like google analytics, favicons).
However, since adopting ng add @angular/pwa
, it is quietly complaining about SwCriticalError: Hash mismatch
because after hashing index.html
it no longer matches the hash in ngsw.json
.
As a consequence, no event is ever emitted by .available
:
constructor(private updates: SwUpdate){
interval(5000).pipe(exhaustMap(() => this.updates.checkForUpdate())).subscribe();
this.updates.available.subscribe(event => console.log('available!'));
}
I tried to run ./node_modules/.bin/ngsw-config dist/ ngsw-config.json
manually, though it does update the index.html
hash at ngsw.json
. It add new hashes and reference for ngsw-worker.js
, safety-worker.js
and worker-basic.min.js
, of which i feel is not intended to be there.
If there isn't a 'canon' solution, i would probably (using gulp
) hash index.html
and assign to its ngsw.json
entry.
angular service-worker progressive-web-apps angular-pwa
add a comment |
I need to inject this tag into a location in the compiled index.html
after running ng build --prod
.
<script>const VERSION = '1.0.0-{someCompileTimeValue}';</script>
Normally, after building, i would use gulp-inject
to inject that tag (including other things like google analytics, favicons).
However, since adopting ng add @angular/pwa
, it is quietly complaining about SwCriticalError: Hash mismatch
because after hashing index.html
it no longer matches the hash in ngsw.json
.
As a consequence, no event is ever emitted by .available
:
constructor(private updates: SwUpdate){
interval(5000).pipe(exhaustMap(() => this.updates.checkForUpdate())).subscribe();
this.updates.available.subscribe(event => console.log('available!'));
}
I tried to run ./node_modules/.bin/ngsw-config dist/ ngsw-config.json
manually, though it does update the index.html
hash at ngsw.json
. It add new hashes and reference for ngsw-worker.js
, safety-worker.js
and worker-basic.min.js
, of which i feel is not intended to be there.
If there isn't a 'canon' solution, i would probably (using gulp
) hash index.html
and assign to its ngsw.json
entry.
angular service-worker progressive-web-apps angular-pwa
add a comment |
I need to inject this tag into a location in the compiled index.html
after running ng build --prod
.
<script>const VERSION = '1.0.0-{someCompileTimeValue}';</script>
Normally, after building, i would use gulp-inject
to inject that tag (including other things like google analytics, favicons).
However, since adopting ng add @angular/pwa
, it is quietly complaining about SwCriticalError: Hash mismatch
because after hashing index.html
it no longer matches the hash in ngsw.json
.
As a consequence, no event is ever emitted by .available
:
constructor(private updates: SwUpdate){
interval(5000).pipe(exhaustMap(() => this.updates.checkForUpdate())).subscribe();
this.updates.available.subscribe(event => console.log('available!'));
}
I tried to run ./node_modules/.bin/ngsw-config dist/ ngsw-config.json
manually, though it does update the index.html
hash at ngsw.json
. It add new hashes and reference for ngsw-worker.js
, safety-worker.js
and worker-basic.min.js
, of which i feel is not intended to be there.
If there isn't a 'canon' solution, i would probably (using gulp
) hash index.html
and assign to its ngsw.json
entry.
angular service-worker progressive-web-apps angular-pwa
I need to inject this tag into a location in the compiled index.html
after running ng build --prod
.
<script>const VERSION = '1.0.0-{someCompileTimeValue}';</script>
Normally, after building, i would use gulp-inject
to inject that tag (including other things like google analytics, favicons).
However, since adopting ng add @angular/pwa
, it is quietly complaining about SwCriticalError: Hash mismatch
because after hashing index.html
it no longer matches the hash in ngsw.json
.
As a consequence, no event is ever emitted by .available
:
constructor(private updates: SwUpdate){
interval(5000).pipe(exhaustMap(() => this.updates.checkForUpdate())).subscribe();
this.updates.available.subscribe(event => console.log('available!'));
}
I tried to run ./node_modules/.bin/ngsw-config dist/ ngsw-config.json
manually, though it does update the index.html
hash at ngsw.json
. It add new hashes and reference for ngsw-worker.js
, safety-worker.js
and worker-basic.min.js
, of which i feel is not intended to be there.
If there isn't a 'canon' solution, i would probably (using gulp
) hash index.html
and assign to its ngsw.json
entry.
angular service-worker progressive-web-apps angular-pwa
angular service-worker progressive-web-apps angular-pwa
asked Dec 28 '18 at 3:17


GheloAce
84911424
84911424
add a comment |
add a comment |
0
active
oldest
votes
Your Answer
StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");
StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "1"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});
function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});
}
});
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53953292%2fhow-to-inject-extra-html-to-index-html-during-angular-production-build-before-it%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
0
active
oldest
votes
0
active
oldest
votes
active
oldest
votes
active
oldest
votes
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Some of your past answers have not been well-received, and you're in danger of being blocked from answering.
Please pay close attention to the following guidance:
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53953292%2fhow-to-inject-extra-html-to-index-html-during-angular-production-build-before-it%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
C1AgwLRPSEglgqPgUOzw50k 1D7uyKUPS6Bn2Wy,Xcw1EKbNDijJ18C,R39olg