forked from firebase/quickstart-js
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.html
111 lines (97 loc) · 3.98 KB
/
index.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
<!DOCTYPE html>
<!--
Copyright (c) 2019 Google Inc.
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.
-->
<html>
<head>
<meta charset=utf-8 />
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Firebase Remote Config Example</title>
<!-- Material Design Theming -->
<link rel="stylesheet" href="https://code.getmdl.io/1.1.3/material.orange-indigo.min.css">
<link rel="stylesheet" href="https://fonts.googleapis.com/icon?family=Material+Icons">
<script defer src="https://code.getmdl.io/1.1.3/material.min.js"></script>
<link rel="stylesheet" href="main.css">
</head>
<body>
<div class="demo-layout mdl-layout mdl-js-layout mdl-layout--fixed-header">
<!-- Header section containing title -->
<header class="mdl-layout__header mdl-color-text--white mdl-color--light-blue-700">
<div class="mdl-cell mdl-cell--12-col mdl-cell--12-col-tablet mdl-grid">
<div class="mdl-layout__header-row mdl-cell mdl-cell--12-col mdl-cell--12-col-tablet mdl-cell--8-col-desktop">
<h3>Firebase Remote Config</h3>
</div>
</div>
</header>
<main class="mdl-layout__content mdl-color--grey-100">
<div class="mdl-cell mdl-cell--12-col mdl-cell--12-col-tablet mdl-grid">
<!-- Container for the Table of content -->
<div class="mdl-card mdl-shadow--2dp mdl-cell mdl-cell--12-col mdl-cell--12-col-tablet mdl-cell--12-col-desktop">
<div class="mdl-card__supporting-text mdl-color-text--grey-600">
<!-- div to display button to fetch latest config -->
<div id="fetch_div">
<h4>Welcome Message:</h4>
<p id="welcome_message">loading...</p>
<button class="mdl-button mdl-js-button mdl-button--raised mdl-button--colored"
onclick="fetchConfig()">Fetch Remote Welcome</button>
</div>
</div>
</div>
</div>
</main>
</div>
<!-- Import and configure the Firebase SDK -->
<!-- These scripts are made available when the app is served or deployed on Firebase Hosting -->
<!-- If you do not serve/host your project using Firebase Hosting see https://firebase.google.com/docs/web/setup -->
<script src="/__/firebase/9.8.3/firebase-app-compat.js"></script>
<script src="/__/firebase/9.8.3/firebase-remote-config.js"></script>
<script src="/__/firebase/init.js"></script>
<script>
const remoteConfig = firebase.remoteConfig();
remoteConfig.settings = {
minimumFetchIntervalMillis: 3600000,
};
remoteConfig.defaultConfig = ({
'welcome_message': 'Welcome',
});
remoteConfig.ensureInitialized()
.then(() => {
console.log('Firebase Remote Config is initialized');
showWelcomeMessage();
})
.catch((err) => {
console.error('Firebase Remote Config failed to initialize', err);
});
function showWelcomeMessage() {
// If you are only interested in the value then you can get it
// directly using one of the typed getters:
//
// const msg = remoteConfig.getString('welcome_message');
// To get the value and source of the parameter use `getValue`.
const val = remoteConfig.getValue('welcome_message');
const welcome_element = document.getElementById('welcome_message');
welcome_element.innerText = val._value + ' (' + val._source + ')';
}
function fetchConfig() {
const welcome_element = document.getElementById('welcome_message');
welcome_element.innerText = 'loading...';
remoteConfig.fetchAndActivate()
.then(() => {
showWelcomeMessage();
})
.catch((err) => {
console.error(err);
});
}
</script>
</body>
</html>