This repository has been archived by the owner on May 8, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 33
/
Copy pathapp.js
124 lines (112 loc) · 3.31 KB
/
app.js
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
112
113
114
115
116
117
118
119
120
121
122
123
124
(function () {
/**
* Initializes the application and required dependencies, such as:
* - Contentful client
* - Configuration for the application
* - History API event listeners
* - Event delegation for handling anchor links throughout the app and allowing
* navigation through the use of pushState and the History API
*/
PC.init = function () {
// Initializes the Contentful client with the required credentials for a
// product catalog space. Feel free to replace them with our own.
PC.contentfulClient = contentful.createClient({
accessToken: 'f35d62ae3f7c737f1a0b28eac0a035aa41f45b8239f37f41051110e052753d18',
space: 'bkp1t915hkvx'
})
// IDs of some of the Content Types used in the app
PC.config = {
productContentTypeId: 'product',
categoryContentTypeId: 'category'
}
setupHistory()
setupNavAnchorListeners()
// main container for rendering the app
PC.container = document.getElementById('content')
// load the requested route
loadPage(window.location.href)
}
// Navigates to a given page via the history API
PC.navigate = function (href) {
window.history.pushState({href: href}, '', href)
loadPage(href)
}
/**
* Sets up the popstate listener
* https://developer.mozilla.org/en-US/docs/Web/API/WindowEventHandlers/onpopstate
*/
function setupHistory() {
window.onpopstate = function (ev) {
loadPage(ev.state && ev.state.href || '')
}
}
/**
* Event delegation mechanism for links throughout the app
*
* Listens to all click events in the app, and if the source element is an anchor
* tag and has a data-nav property, it cancels the event and loads the page
* referred in the href with the loadPage function, while also pushing it
* to the history API
*/
function setupNavAnchorListeners() {
document.querySelector('body').addEventListener('click', function (ev) {
ev.preventDefault()
if(ev.target.tagName.toLowerCase() === 'a' && 'nav' in ev.target.dataset) {
PC.navigate(ev.target.href)
}
}, false)
}
/**
* Basic routing mechanism
*
* Removes the URL from the href (which can come from either an anchor tag or
* the popstate event), and splits it by '/'.
*/
function loadPage(href) {
href = href.replace(document.baseURI, '')
var urlParts = href.split('/')
var pageName = urlParts[0]
// Attempts to get the object which contains the methods to render and setup
// pages, otherwise defaults to the main page
var page = PC.pages[pageName] || PC.pages.products
var loader
switch(pageName) {
// /categories and /categories/:id
case 'categories':
loader = page.renderHTML({
selectedCategoryId: urlParts[1],
})
break
// /about
case 'about':
loader = page.renderHTML()
break
// /product/:id
case 'product':
loader = page.renderHTML({
productSlug: urlParts[1]
})
break
// /brand/:id
case 'brand':
loader = page.renderHTML({
brandId: urlParts[1]
})
break
// / (index page)
default:
loader = page.renderHTML()
}
loader.then(injectInPage).then(function () {
// after rendering is done, run the postRender method if there is one
if('postRender' in page) {
setTimeout(function () {
page.postRender()
}, 0)
}
})
}
function injectInPage (HTMLContent) {
PC.container.innerHTML = HTMLContent
}
}());