fragmented 3.1.3 → 3.1.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +13 -11
- package/example.js +100 -31
- package/lib/constants.js +17 -4
- package/lib/fragmented.js +70 -19
- package/lib/index.js +4 -1
- package/package.json +1 -1
- package/src/constants.js +2 -0
- package/src/fragmented.js +91 -23
- package/src/index.js +1 -1
package/README.md
CHANGED
|
@@ -2,9 +2,9 @@
|
|
|
2
2
|
|
|
3
3
|
Relates to URL hash fragments.
|
|
4
4
|
|
|
5
|
-
Fragmented allows your application to affect and be affected by the hash fragment of the URL in the browser's address bar. Changes to the fragment are invisible to the server whilst being included in the browser's history. For this reason fragments are useful to single page applications that need the back and forward buttons to work for them
|
|
5
|
+
Fragmented allows your application to affect and be affected by the hash fragment of the URL in the browser's address bar. Changes to the fragment are invisible to the server whilst being included in the browser's history. For this reason fragments are useful to single page applications that need the back and forward buttons to work for them without triggering Ajax requests and the like.
|
|
6
6
|
|
|
7
|
-
|
|
7
|
+
Fragmented provides a global [`fragment`](https://github.com/djalbat/Fragmented/blob/master/es6/fragmented.js) variable which corresponds to the aforementioned hash fragment in the browser's address bar and the value of which the application can get or set. It also provides `onFragmentChange` and `offFragmentChange` functions so that handlers can be registered and unregistered.
|
|
8
8
|
|
|
9
9
|
## Installation
|
|
10
10
|
|
|
@@ -42,7 +42,7 @@ One last thing to bear in mind is that this package is included by way of a rela
|
|
|
42
42
|
|
|
43
43
|
## Usage
|
|
44
44
|
|
|
45
|
-
|
|
45
|
+
In order to make use of the global `fragmented` variable you only need to import the package:
|
|
46
46
|
|
|
47
47
|
```
|
|
48
48
|
import "fragmented";
|
|
@@ -60,12 +60,14 @@ To set the fragment:
|
|
|
60
60
|
fragment = "test";
|
|
61
61
|
```
|
|
62
62
|
|
|
63
|
-
|
|
63
|
+
When you set the fragment like this any handlers will be called.
|
|
64
|
+
|
|
65
|
+
To register and unregister handlers:
|
|
64
66
|
|
|
65
67
|
```
|
|
66
68
|
const { onFragmentChange, offFragmentChange } = fragment;
|
|
67
69
|
|
|
68
|
-
|
|
70
|
+
const fragmentChangeHandler = () {
|
|
69
71
|
console.log(fragment)
|
|
70
72
|
}
|
|
71
73
|
|
|
@@ -74,25 +76,25 @@ onFragmentChange(fragmentChangeHandler);
|
|
|
74
76
|
// offFragmentChange(fragmentChangeHandler);
|
|
75
77
|
```
|
|
76
78
|
|
|
77
|
-
Note that
|
|
79
|
+
Note that handlers are invoked whenever the `fragment` variable is set. If you do not want this behaviour, in other words you want to be able to change the fragment in the address bar without your handlers being invoked, you can to this with an additional `setFragment()` function as follows:
|
|
78
80
|
|
|
79
81
|
```
|
|
80
82
|
const { setFragment } = fragment;
|
|
81
83
|
|
|
82
|
-
setFragment("test"); //
|
|
84
|
+
setFragment("test"); // handlers won't be invoked
|
|
83
85
|
```
|
|
84
86
|
|
|
85
|
-
Also note that the `fragment` variable is an instance of the `String` object, rather than a string primitive, in order that properties on it can be defined. So use `==` rather than `===` if equating it to a string primitive.
|
|
87
|
+
Also note that the `fragment` variable is an instance of the `String` object, rather than a string primitive, in order that properties on it can be defined. So use `==` rather than `===` if equating it to a string primitive. And note that if you use a `switch` statement, which uses strict equality, you will need to explicitly coerce the `fragment` variable to a string primitive before passing it in.
|
|
86
88
|
|
|
87
|
-
|
|
89
|
+
By the way, you can import these functions more conventionally if you think that destructuring the global `fragment` variable is a bit too cute:
|
|
88
90
|
|
|
89
91
|
```
|
|
90
|
-
import { getFragment, setFragment, onFragmentChange, offFragmentChange } from "fragmented";
|
|
92
|
+
import { getFragment, setFragment, resetFragment, onFragmentChange, offFragmentChange } from "fragmented";
|
|
91
93
|
|
|
92
94
|
...
|
|
93
95
|
```
|
|
94
96
|
|
|
95
|
-
Finally
|
|
97
|
+
Finally, the `resetFrageent()` function does as its name suggests, essentially removing the fragment altogether.
|
|
96
98
|
|
|
97
99
|
## Building
|
|
98
100
|
|
package/example.js
CHANGED
|
@@ -7,34 +7,48 @@
|
|
|
7
7
|
return module.exports;
|
|
8
8
|
};
|
|
9
9
|
|
|
10
|
-
// lib/
|
|
11
|
-
var
|
|
10
|
+
// lib/eventTypes.js
|
|
11
|
+
var require_eventTypes = __commonJS((exports) => {
|
|
12
12
|
"use strict";
|
|
13
13
|
Object.defineProperty(exports, "__esModule", {
|
|
14
14
|
value: true
|
|
15
15
|
});
|
|
16
|
-
Object.defineProperty(exports, "
|
|
16
|
+
Object.defineProperty(exports, "HASHCHANGE_EVENT_TYPE", {
|
|
17
17
|
enumerable: true,
|
|
18
18
|
get: function() {
|
|
19
|
-
return
|
|
19
|
+
return HASHCHANGE_EVENT_TYPE;
|
|
20
20
|
}
|
|
21
21
|
});
|
|
22
|
-
var
|
|
22
|
+
var HASHCHANGE_EVENT_TYPE = "hashchange";
|
|
23
23
|
});
|
|
24
24
|
|
|
25
|
-
// lib/
|
|
26
|
-
var
|
|
25
|
+
// lib/constants.js
|
|
26
|
+
var require_constants = __commonJS((exports) => {
|
|
27
27
|
"use strict";
|
|
28
28
|
Object.defineProperty(exports, "__esModule", {
|
|
29
29
|
value: true
|
|
30
30
|
});
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
31
|
+
function _export(target, all) {
|
|
32
|
+
for (var name in all)
|
|
33
|
+
Object.defineProperty(target, name, {
|
|
34
|
+
enumerable: true,
|
|
35
|
+
get: all[name]
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
_export(exports, {
|
|
39
|
+
EMPTY_STRING: function() {
|
|
40
|
+
return EMPTY_STRING;
|
|
41
|
+
},
|
|
42
|
+
FRAGMENT: function() {
|
|
43
|
+
return FRAGMENT;
|
|
44
|
+
},
|
|
45
|
+
HASH: function() {
|
|
46
|
+
return HASH;
|
|
35
47
|
}
|
|
36
48
|
});
|
|
37
|
-
var
|
|
49
|
+
var HASH = "#";
|
|
50
|
+
var FRAGMENT = "fragment";
|
|
51
|
+
var EMPTY_STRING = "";
|
|
38
52
|
});
|
|
39
53
|
|
|
40
54
|
// lib/fragmented.js
|
|
@@ -60,17 +74,21 @@
|
|
|
60
74
|
onFragmentChange: function() {
|
|
61
75
|
return onFragmentChange;
|
|
62
76
|
},
|
|
77
|
+
resetFragment: function() {
|
|
78
|
+
return resetFragment;
|
|
79
|
+
},
|
|
63
80
|
setFragment: function() {
|
|
64
81
|
return setFragment;
|
|
65
82
|
}
|
|
66
83
|
});
|
|
67
|
-
var _constants = require_constants();
|
|
68
84
|
var _eventTypes = require_eventTypes();
|
|
85
|
+
var _constants = require_constants();
|
|
69
86
|
function getFragment() {
|
|
70
87
|
var hash = getHash(), fragment2 = new String(hash);
|
|
71
88
|
Object.assign(fragment2, {
|
|
72
89
|
getFragment,
|
|
73
90
|
setFragment,
|
|
91
|
+
resetFragment,
|
|
74
92
|
onFragmentChange,
|
|
75
93
|
offFragmentChange
|
|
76
94
|
});
|
|
@@ -78,10 +96,10 @@
|
|
|
78
96
|
}
|
|
79
97
|
function setFragment(fragment2) {
|
|
80
98
|
var silently = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : true;
|
|
81
|
-
var hash = fragment2;
|
|
82
99
|
if (silently) {
|
|
83
100
|
window.removeEventListener(eventType, hashChangeListener);
|
|
84
101
|
}
|
|
102
|
+
var hash = fragment2;
|
|
85
103
|
window.location.hash = hash;
|
|
86
104
|
if (silently) {
|
|
87
105
|
setTimeout(function() {
|
|
@@ -89,17 +107,33 @@
|
|
|
89
107
|
}, 0);
|
|
90
108
|
}
|
|
91
109
|
}
|
|
110
|
+
function resetFragment() {
|
|
111
|
+
var silently = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : true;
|
|
112
|
+
if (silently) {
|
|
113
|
+
window.removeEventListener(eventType, hashChangeListener);
|
|
114
|
+
}
|
|
115
|
+
var href = location.href;
|
|
116
|
+
var index = href.indexOf(_constants.HASH);
|
|
117
|
+
if (index !== -1) {
|
|
118
|
+
var start = 0, end = index;
|
|
119
|
+
href = href.substring(start, end);
|
|
120
|
+
history.pushState({}, _constants.EMPTY_STRING, href);
|
|
121
|
+
}
|
|
122
|
+
if (silently) {
|
|
123
|
+
setTimeout(function() {
|
|
124
|
+
window.addEventListener(eventType, hashChangeListener);
|
|
125
|
+
}, 0);
|
|
126
|
+
}
|
|
127
|
+
}
|
|
92
128
|
function onFragmentChange(fragmentChangeHandler) {
|
|
93
|
-
|
|
129
|
+
var element = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : this;
|
|
130
|
+
addFragmentChangeEventListener(fragmentChangeHandler, element);
|
|
94
131
|
}
|
|
95
132
|
function offFragmentChange(fragmentChangeHandler) {
|
|
96
|
-
var
|
|
97
|
-
|
|
98
|
-
var start = index, deleteCount = 1;
|
|
99
|
-
fragmentChangeHandlers.splice(start, deleteCount);
|
|
100
|
-
}
|
|
133
|
+
var element = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : this;
|
|
134
|
+
removeFragmentChangeEventListener(fragmentChangeHandler, element);
|
|
101
135
|
}
|
|
102
|
-
Object.defineProperty(
|
|
136
|
+
Object.defineProperty(globalThis, _constants.FRAGMENT, {
|
|
103
137
|
get: function get() {
|
|
104
138
|
var fragment2 = getFragment();
|
|
105
139
|
return fragment2;
|
|
@@ -110,21 +144,53 @@
|
|
|
110
144
|
}
|
|
111
145
|
});
|
|
112
146
|
var eventType = _eventTypes.HASHCHANGE_EVENT_TYPE;
|
|
113
|
-
var
|
|
147
|
+
var fragmentChangeEventListeners = [];
|
|
114
148
|
window.addEventListener(eventType, hashChangeListener);
|
|
115
|
-
function hashChangeListener(event) {
|
|
116
|
-
var hash = getHash(), fragment2 = hash;
|
|
117
|
-
fragmentChangeHandlers.forEach(function(fragmentChangeHandler) {
|
|
118
|
-
fragmentChangeHandler(event, fragment2);
|
|
119
|
-
});
|
|
120
|
-
}
|
|
121
149
|
function getHash() {
|
|
122
|
-
var
|
|
123
|
-
var hash =
|
|
150
|
+
var location1 = window.location;
|
|
151
|
+
var hash = location1.hash;
|
|
124
152
|
var start = 1;
|
|
125
153
|
hash = hash.substring(start);
|
|
126
154
|
return hash;
|
|
127
155
|
}
|
|
156
|
+
function hashChangeListener(event) {
|
|
157
|
+
var hash = getHash(), element = window, fragment2 = hash;
|
|
158
|
+
callFragmentChangeHandlers(event, element, fragment2);
|
|
159
|
+
}
|
|
160
|
+
function callFragmentChangeHandlers(event, element, fragment2) {
|
|
161
|
+
fragmentChangeEventListeners.forEach(function(fragmentChangeEventListener) {
|
|
162
|
+
var fragmentChangeHandler = fragmentChangeEventListener.fragmentChangeHandler, fragmentChangeHandlerElement = fragmentChangeEventListener.element;
|
|
163
|
+
fragmentChangeHandler.call(fragmentChangeHandlerElement, event, element, fragment2);
|
|
164
|
+
});
|
|
165
|
+
}
|
|
166
|
+
function addFragmentChangeEventListener(fragmentChangeHandler, element) {
|
|
167
|
+
var fragmentChangeEventListener = createFragmentChangeEventListener(fragmentChangeHandler, element);
|
|
168
|
+
fragmentChangeEventListeners.push(fragmentChangeEventListener);
|
|
169
|
+
return fragmentChangeEventListener;
|
|
170
|
+
}
|
|
171
|
+
function removeFragmentChangeEventListener(fragmentChangeHandler, element) {
|
|
172
|
+
var fragmentChangeEventListener = findFragmentChangeEventListener(fragmentChangeHandler, element), index = fragmentChangeEventListeners.indexOf(fragmentChangeEventListener), start = index, deleteCount = 1;
|
|
173
|
+
fragmentChangeEventListeners.splice(start, deleteCount);
|
|
174
|
+
return fragmentChangeEventListener;
|
|
175
|
+
}
|
|
176
|
+
function createFragmentChangeEventListener(fragmentChangeHandler, element) {
|
|
177
|
+
var fragmentChangeEventListener;
|
|
178
|
+
fragmentChangeEventListener = function() {
|
|
179
|
+
};
|
|
180
|
+
Object.assign(fragmentChangeEventListener, {
|
|
181
|
+
element,
|
|
182
|
+
fragmentChangeHandler
|
|
183
|
+
});
|
|
184
|
+
return fragmentChangeEventListener;
|
|
185
|
+
}
|
|
186
|
+
function findFragmentChangeEventListener(fragmentChangeHandler, element) {
|
|
187
|
+
var fragmentChangeEventListener = fragmentChangeEventListeners.find(function(fragmentChangeEventListener2) {
|
|
188
|
+
if (fragmentChangeEventListener2.element === element && fragmentChangeEventListener2.fragmentChangeHandler === fragmentChangeHandler) {
|
|
189
|
+
return true;
|
|
190
|
+
}
|
|
191
|
+
});
|
|
192
|
+
return fragmentChangeEventListener;
|
|
193
|
+
}
|
|
128
194
|
});
|
|
129
195
|
|
|
130
196
|
// lib/index.js
|
|
@@ -150,6 +216,9 @@
|
|
|
150
216
|
onFragmentChange: function() {
|
|
151
217
|
return _fragmented.onFragmentChange;
|
|
152
218
|
},
|
|
219
|
+
resetFragment: function() {
|
|
220
|
+
return _fragmented.resetFragment;
|
|
221
|
+
},
|
|
153
222
|
setFragment: function() {
|
|
154
223
|
return _fragmented.setFragment;
|
|
155
224
|
}
|
|
@@ -175,4 +244,4 @@
|
|
|
175
244
|
});
|
|
176
245
|
require_example();
|
|
177
246
|
})();
|
|
178
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
247
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["src/eventTypes.js", "src/constants.js", "src/fragmented.js", "src/index.js", "src/example.js"],
  "sourcesContent": ["\"use strict\";\n\nexport const HASHCHANGE_EVENT_TYPE = \"hashchange\";\n", "\"use strict\";\n\nexport const HASH = \"#\";\nexport const FRAGMENT = \"fragment\";\nexport const EMPTY_STRING = \"\";", "\"use strict\";\n\nimport { HASHCHANGE_EVENT_TYPE } from \"./eventTypes\";\nimport { HASH, FRAGMENT, EMPTY_STRING } from \"./constants\";\n\nexport function getFragment() {\n  const hash = getHash(),\n        fragment = new String(hash);  ///\n\n  Object.assign(fragment, {\n    getFragment,\n    setFragment,\n    resetFragment,\n    onFragmentChange,\n    offFragmentChange\n  });\n\n  return fragment;\n}\n\nexport function setFragment(fragment, silently = true) {\n  if (silently) {\n    window.removeEventListener(eventType, hashChangeListener);\n  }\n\n  const hash = fragment;  ///\n\n  window.location.hash = hash;\n\n  if (silently) {\n    setTimeout(() => {\n      window.addEventListener(eventType, hashChangeListener);\n    }, 0);\n  }\n}\n\nexport function resetFragment(silently = true) {\n  if (silently) {\n    window.removeEventListener(eventType, hashChangeListener);\n  }\n\n  let { href } = location;\n\n  const index = href.indexOf(HASH);\n\n  if (index !== -1) {\n    const start = 0,\n          end = index;  ///\n\n    href = href.substring(start, end); ///\n\n    history.pushState({}, EMPTY_STRING, href);\n  }\n\n  if (silently) {\n    setTimeout(() => {\n      window.addEventListener(eventType, hashChangeListener);\n    }, 0);\n  }\n}\n\nexport function onFragmentChange(fragmentChangeHandler, element = this) {\n  addFragmentChangeEventListener(fragmentChangeHandler, element);\n}\n\nexport function offFragmentChange(fragmentChangeHandler, element = this) {\n  removeFragmentChangeEventListener(fragmentChangeHandler, element);\n}\n\nObject.defineProperty(globalThis, FRAGMENT, {\n  get: function() {\n    const fragment = getFragment();\n\n    return fragment;\n  },\n\n  set: function(fragment) {\n    const silently = false;\n\n    setFragment(fragment, silently);\n  }\n});\n\nconst eventType = HASHCHANGE_EVENT_TYPE,\n      fragmentChangeEventListeners = [];\n\nwindow.addEventListener(eventType, hashChangeListener);\n\nfunction getHash() {\n  const { location } = window;\n\n  let { hash } = location;\n\n  const start = 1;\n\n  hash = hash.substring(start);\n\n  return hash;\n}\n\nfunction hashChangeListener(event) {\n  const hash = getHash(),\n        element = window, ///\n        fragment = hash;  ///\n\n  callFragmentChangeHandlers(event, element, fragment);\n}\n\nfunction callFragmentChangeHandlers(event, element, fragment) {\n  fragmentChangeEventListeners.forEach((fragmentChangeEventListener) => {\n    const { fragmentChangeHandler, element: fragmentChangeHandlerElement } = fragmentChangeEventListener; ///\n\n    fragmentChangeHandler.call(fragmentChangeHandlerElement, event, element, fragment);\n  });\n}\n\nfunction addFragmentChangeEventListener(fragmentChangeHandler, element) {\n  const fragmentChangeEventListener = createFragmentChangeEventListener(fragmentChangeHandler, element);\n\n  fragmentChangeEventListeners.push(fragmentChangeEventListener);\n\n  return fragmentChangeEventListener;\n}\n\nfunction removeFragmentChangeEventListener(fragmentChangeHandler, element) {\n  const fragmentChangeEventListener = findFragmentChangeEventListener(fragmentChangeHandler, element),\n        index = fragmentChangeEventListeners.indexOf(fragmentChangeEventListener),\n        start = index,  ///\n        deleteCount = 1;\n\n  fragmentChangeEventListeners.splice(start, deleteCount);\n\n  return fragmentChangeEventListener;\n}\n\nfunction createFragmentChangeEventListener(fragmentChangeHandler, element) {\n  let fragmentChangeEventListener;\n\n  fragmentChangeEventListener = () => {}; ///\n\n  Object.assign(fragmentChangeEventListener, {\n    element,\n    fragmentChangeHandler\n  });\n\n  return fragmentChangeEventListener;\n}\n\nfunction findFragmentChangeEventListener(fragmentChangeHandler, element) {\n  const fragmentChangeEventListener = fragmentChangeEventListeners.find((fragmentChangeEventListener) => {\n    if ((fragmentChangeEventListener.element === element) && (fragmentChangeEventListener.fragmentChangeHandler === fragmentChangeHandler)) {\n      return true;\n    }\n  });\n\n  return fragmentChangeEventListener;\n}\n", "\"use strict\";\n\nimport \"./fragmented\";\n\nexport { getFragment, setFragment, resetFragment, onFragmentChange, offFragmentChange } from \"./fragmented\";\n\n", "\"use strict\";\n\nimport \"./index\"; ///\n\nconst { onFragmentChange, offFragmentChange } = fragment;\n\nonFragmentChange(fragmentChangeHandler);\n\nconsole.log(fragment)\n\nfragment = \"test\";\n\n// offFragmentChange(fragmentChangeHandler);\n\nfunction fragmentChangeHandler() {\n  console.log(fragment)\n}\n"],
  "mappings": "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",
  "names": []
}

|
package/lib/constants.js
CHANGED
|
@@ -2,12 +2,25 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", {
|
|
3
3
|
value: true
|
|
4
4
|
});
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
5
|
+
function _export(target, all) {
|
|
6
|
+
for(var name in all)Object.defineProperty(target, name, {
|
|
7
|
+
enumerable: true,
|
|
8
|
+
get: all[name]
|
|
9
|
+
});
|
|
10
|
+
}
|
|
11
|
+
_export(exports, {
|
|
12
|
+
EMPTY_STRING: function() {
|
|
13
|
+
return EMPTY_STRING;
|
|
14
|
+
},
|
|
15
|
+
FRAGMENT: function() {
|
|
8
16
|
return FRAGMENT;
|
|
17
|
+
},
|
|
18
|
+
HASH: function() {
|
|
19
|
+
return HASH;
|
|
9
20
|
}
|
|
10
21
|
});
|
|
22
|
+
var HASH = "#";
|
|
11
23
|
var FRAGMENT = "fragment";
|
|
24
|
+
var EMPTY_STRING = "";
|
|
12
25
|
|
|
13
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9jb25zdGFudHMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiXCJ1c2Ugc3RyaWN0XCI7XG5cbmV4cG9ydCBjb25zdCBIQVNIID0gXCIjXCI7XG5leHBvcnQgY29uc3QgRlJBR01FTlQgPSBcImZyYWdtZW50XCI7XG5leHBvcnQgY29uc3QgRU1QVFlfU1RSSU5HID0gXCJcIjsiXSwibmFtZXMiOlsiRU1QVFlfU1RSSU5HIiwiRlJBR01FTlQiLCJIQVNIIl0sInJhbmdlTWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OyIsIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7Ozs7SUFJYUEsWUFBWTtlQUFaQTs7SUFEQUMsUUFBUTtlQUFSQTs7SUFEQUMsSUFBSTtlQUFKQTs7O0FBQU4sSUFBTUEsT0FBTztBQUNiLElBQU1ELFdBQVc7QUFDakIsSUFBTUQsZUFBZSJ9
|
package/lib/fragmented.js
CHANGED
|
@@ -18,17 +18,21 @@ _export(exports, {
|
|
|
18
18
|
onFragmentChange: function() {
|
|
19
19
|
return onFragmentChange;
|
|
20
20
|
},
|
|
21
|
+
resetFragment: function() {
|
|
22
|
+
return resetFragment;
|
|
23
|
+
},
|
|
21
24
|
setFragment: function() {
|
|
22
25
|
return setFragment;
|
|
23
26
|
}
|
|
24
27
|
});
|
|
25
|
-
var _constants = require("./constants");
|
|
26
28
|
var _eventTypes = require("./eventTypes");
|
|
29
|
+
var _constants = require("./constants");
|
|
27
30
|
function getFragment() {
|
|
28
31
|
var hash = getHash(), fragment = new String(hash); ///
|
|
29
32
|
Object.assign(fragment, {
|
|
30
33
|
getFragment: getFragment,
|
|
31
34
|
setFragment: setFragment,
|
|
35
|
+
resetFragment: resetFragment,
|
|
32
36
|
onFragmentChange: onFragmentChange,
|
|
33
37
|
offFragmentChange: offFragmentChange
|
|
34
38
|
});
|
|
@@ -36,10 +40,10 @@ function getFragment() {
|
|
|
36
40
|
}
|
|
37
41
|
function setFragment(fragment) {
|
|
38
42
|
var silently = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : true;
|
|
39
|
-
var hash = fragment; ///
|
|
40
43
|
if (silently) {
|
|
41
44
|
window.removeEventListener(eventType, hashChangeListener);
|
|
42
45
|
}
|
|
46
|
+
var hash = fragment; ///
|
|
43
47
|
window.location.hash = hash;
|
|
44
48
|
if (silently) {
|
|
45
49
|
setTimeout(function() {
|
|
@@ -47,17 +51,33 @@ function setFragment(fragment) {
|
|
|
47
51
|
}, 0);
|
|
48
52
|
}
|
|
49
53
|
}
|
|
54
|
+
function resetFragment() {
|
|
55
|
+
var silently = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : true;
|
|
56
|
+
if (silently) {
|
|
57
|
+
window.removeEventListener(eventType, hashChangeListener);
|
|
58
|
+
}
|
|
59
|
+
var href = location.href;
|
|
60
|
+
var index = href.indexOf(_constants.HASH);
|
|
61
|
+
if (index !== -1) {
|
|
62
|
+
var start = 0, end = index; ///
|
|
63
|
+
href = href.substring(start, end); ///
|
|
64
|
+
history.pushState({}, _constants.EMPTY_STRING, href);
|
|
65
|
+
}
|
|
66
|
+
if (silently) {
|
|
67
|
+
setTimeout(function() {
|
|
68
|
+
window.addEventListener(eventType, hashChangeListener);
|
|
69
|
+
}, 0);
|
|
70
|
+
}
|
|
71
|
+
}
|
|
50
72
|
function onFragmentChange(fragmentChangeHandler) {
|
|
51
|
-
|
|
73
|
+
var element = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : this;
|
|
74
|
+
addFragmentChangeEventListener(fragmentChangeHandler, element);
|
|
52
75
|
}
|
|
53
76
|
function offFragmentChange(fragmentChangeHandler) {
|
|
54
|
-
var
|
|
55
|
-
|
|
56
|
-
var start = index, deleteCount = 1;
|
|
57
|
-
fragmentChangeHandlers.splice(start, deleteCount);
|
|
58
|
-
}
|
|
77
|
+
var element = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : this;
|
|
78
|
+
removeFragmentChangeEventListener(fragmentChangeHandler, element);
|
|
59
79
|
}
|
|
60
|
-
Object.defineProperty(
|
|
80
|
+
Object.defineProperty(globalThis, _constants.FRAGMENT, {
|
|
61
81
|
get: function get() {
|
|
62
82
|
var fragment = getFragment();
|
|
63
83
|
return fragment;
|
|
@@ -67,20 +87,51 @@ Object.defineProperty(window, _constants.FRAGMENT, {
|
|
|
67
87
|
setFragment(fragment, silently);
|
|
68
88
|
}
|
|
69
89
|
});
|
|
70
|
-
var eventType = _eventTypes.HASHCHANGE_EVENT_TYPE,
|
|
90
|
+
var eventType = _eventTypes.HASHCHANGE_EVENT_TYPE, fragmentChangeEventListeners = [];
|
|
71
91
|
window.addEventListener(eventType, hashChangeListener);
|
|
72
|
-
function hashChangeListener(event) {
|
|
73
|
-
var hash = getHash(), fragment = hash; ///
|
|
74
|
-
fragmentChangeHandlers.forEach(function(fragmentChangeHandler) {
|
|
75
|
-
fragmentChangeHandler(event, fragment);
|
|
76
|
-
});
|
|
77
|
-
}
|
|
78
92
|
function getHash() {
|
|
79
|
-
var
|
|
80
|
-
var hash =
|
|
93
|
+
var location1 = window.location;
|
|
94
|
+
var hash = location1.hash;
|
|
81
95
|
var start = 1;
|
|
82
96
|
hash = hash.substring(start);
|
|
83
97
|
return hash;
|
|
84
98
|
}
|
|
99
|
+
function hashChangeListener(event) {
|
|
100
|
+
var hash = getHash(), element = window, fragment = hash; ///
|
|
101
|
+
callFragmentChangeHandlers(event, element, fragment);
|
|
102
|
+
}
|
|
103
|
+
function callFragmentChangeHandlers(event, element, fragment) {
|
|
104
|
+
fragmentChangeEventListeners.forEach(function(fragmentChangeEventListener) {
|
|
105
|
+
var fragmentChangeHandler = fragmentChangeEventListener.fragmentChangeHandler, fragmentChangeHandlerElement = fragmentChangeEventListener.element; ///
|
|
106
|
+
fragmentChangeHandler.call(fragmentChangeHandlerElement, event, element, fragment);
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
function addFragmentChangeEventListener(fragmentChangeHandler, element) {
|
|
110
|
+
var fragmentChangeEventListener = createFragmentChangeEventListener(fragmentChangeHandler, element);
|
|
111
|
+
fragmentChangeEventListeners.push(fragmentChangeEventListener);
|
|
112
|
+
return fragmentChangeEventListener;
|
|
113
|
+
}
|
|
114
|
+
function removeFragmentChangeEventListener(fragmentChangeHandler, element) {
|
|
115
|
+
var fragmentChangeEventListener = findFragmentChangeEventListener(fragmentChangeHandler, element), index = fragmentChangeEventListeners.indexOf(fragmentChangeEventListener), start = index, deleteCount = 1;
|
|
116
|
+
fragmentChangeEventListeners.splice(start, deleteCount);
|
|
117
|
+
return fragmentChangeEventListener;
|
|
118
|
+
}
|
|
119
|
+
function createFragmentChangeEventListener(fragmentChangeHandler, element) {
|
|
120
|
+
var fragmentChangeEventListener;
|
|
121
|
+
fragmentChangeEventListener = function() {}; ///
|
|
122
|
+
Object.assign(fragmentChangeEventListener, {
|
|
123
|
+
element: element,
|
|
124
|
+
fragmentChangeHandler: fragmentChangeHandler
|
|
125
|
+
});
|
|
126
|
+
return fragmentChangeEventListener;
|
|
127
|
+
}
|
|
128
|
+
function findFragmentChangeEventListener(fragmentChangeHandler, element) {
|
|
129
|
+
var fragmentChangeEventListener = fragmentChangeEventListeners.find(function(fragmentChangeEventListener) {
|
|
130
|
+
if (fragmentChangeEventListener.element === element && fragmentChangeEventListener.fragmentChangeHandler === fragmentChangeHandler) {
|
|
131
|
+
return true;
|
|
132
|
+
}
|
|
133
|
+
});
|
|
134
|
+
return fragmentChangeEventListener;
|
|
135
|
+
}
|
|
85
136
|
|
|
86
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9mcmFnbWVudGVkLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIlwidXNlIHN0cmljdFwiO1xuXG5pbXBvcnQgeyBGUkFHTUVOVCB9IGZyb20gXCIuL2NvbnN0YW50c1wiO1xuaW1wb3J0IHsgSEFTSENIQU5HRV9FVkVOVF9UWVBFIH0gZnJvbSBcIi4vZXZlbnRUeXBlc1wiO1xuXG5leHBvcnQgZnVuY3Rpb24gZ2V0RnJhZ21lbnQoKSB7XG4gIGNvbnN0IGhhc2ggPSBnZXRIYXNoKCksXG4gICAgICAgIGZyYWdtZW50ID0gbmV3IFN0cmluZyhoYXNoKTsgIC8vL1xuXG4gIE9iamVjdC5hc3NpZ24oZnJhZ21lbnQsIHtcbiAgICBnZXRGcmFnbWVudCxcbiAgICBzZXRGcmFnbWVudCxcbiAgICBvbkZyYWdtZW50Q2hhbmdlLFxuICAgIG9mZkZyYWdtZW50Q2hhbmdlXG4gIH0pO1xuXG4gIHJldHVybiBmcmFnbWVudDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHNldEZyYWdtZW50KGZyYWdtZW50LCBzaWxlbnRseSA9IHRydWUpIHtcbiAgY29uc3QgaGFzaCA9IGZyYWdtZW50OyAgLy8vXG5cbiAgaWYgKHNpbGVudGx5KSB7XG4gICAgd2luZG93LnJlbW92ZUV2ZW50TGlzdGVuZXIoZXZlbnRUeXBlLCBoYXNoQ2hhbmdlTGlzdGVuZXIpO1xuICB9XG5cbiAgd2luZG93LmxvY2F0aW9uLmhhc2ggPSBoYXNoO1xuXG4gIGlmIChzaWxlbnRseSkge1xuICAgIHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgd2luZG93LmFkZEV2ZW50TGlzdGVuZXIoZXZlbnRUeXBlLCBoYXNoQ2hhbmdlTGlzdGVuZXIpO1xuICAgIH0sIDApO1xuICB9XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBvbkZyYWdtZW50Q2hhbmdlKGZyYWdtZW50Q2hhbmdlSGFuZGxlcikge1xuICBmcmFnbWVudENoYW5nZUhhbmRsZXJzLnB1c2goZnJhZ21lbnRDaGFuZ2VIYW5kbGVyKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIG9mZkZyYWdtZW50Q2hhbmdlKGZyYWdtZW50Q2hhbmdlSGFuZGxlcikge1xuICBjb25zdCBpbmRleCA9IGZyYWdtZW50Q2hhbmdlSGFuZGxlcnMuaW5kZXhPZihmcmFnbWVudENoYW5nZUhhbmRsZXIpO1xuXG4gIGlmIChpbmRleCA+IC0xKSB7XG4gICAgY29uc3Qgc3RhcnQgPSBpbmRleCwgIC8vL1xuICAgICAgICAgIGRlbGV0ZUNvdW50ID0gMTtcblxuICAgIGZyYWdtZW50Q2hhbmdlSGFuZGxlcnMuc3BsaWNlKHN0YXJ0LCBkZWxldGVDb3VudCk7XG4gIH1cbn1cblxuT2JqZWN0LmRlZmluZVByb3BlcnR5KHdpbmRvdywgRlJBR01FTlQsIHtcbiAgZ2V0OiBmdW5jdGlvbigpIHtcbiAgICBjb25zdCBmcmFnbWVudCA9IGdldEZyYWdtZW50KCk7XG5cbiAgICByZXR1cm4gZnJhZ21lbnQ7XG4gIH0sXG5cbiAgc2V0OiBmdW5jdGlvbihmcmFnbWVudCkge1xuICAgIGNvbnN0IHNpbGVudGx5ID0gZmFsc2U7XG5cbiAgICBzZXRGcmFnbWVudChmcmFnbWVudCwgc2lsZW50bHkpO1xuICB9XG59KTtcblxuY29uc3QgZXZlbnRUeXBlID0gSEFTSENIQU5HRV9FVkVOVF9UWVBFLFxuICAgICAgZnJhZ21lbnRDaGFuZ2VIYW5kbGVycyA9IFtdO1xuXG53aW5kb3cuYWRkRXZlbnRMaXN0ZW5lcihldmVudFR5cGUsIGhhc2hDaGFuZ2VMaXN0ZW5lcik7XG5cbmZ1bmN0aW9uIGhhc2hDaGFuZ2VMaXN0ZW5lcihldmVudCkge1xuICBjb25zdCBoYXNoID0gZ2V0SGFzaCgpLFxuICAgICAgICBmcmFnbWVudCA9IGhhc2g7ICAvLy9cblxuICBmcmFnbWVudENoYW5nZUhhbmRsZXJzLmZvckVhY2goKGZyYWdtZW50Q2hhbmdlSGFuZGxlcikgPT4ge1xuICAgIGZyYWdtZW50Q2hhbmdlSGFuZGxlcihldmVudCwgZnJhZ21lbnQpO1xuICB9KTtcbn1cblxuZnVuY3Rpb24gZ2V0SGFzaCgpIHtcbiAgY29uc3QgeyBsb2NhdGlvbiB9ID0gd2luZG93O1xuXG4gIGxldCB7IGhhc2ggfSA9IGxvY2F0aW9uO1xuXG4gIGNvbnN0IHN0YXJ0ID0gMTtcblxuICBoYXNoID0gaGFzaC5zdWJzdHJpbmcoc3RhcnQpO1xuXG4gIHJldHVybiBoYXNoO1xufSJdLCJuYW1lcyI6WyJnZXRGcmFnbWVudCIsIm9mZkZyYWdtZW50Q2hhbmdlIiwib25GcmFnbWVudENoYW5nZSIsInNldEZyYWdtZW50IiwiaGFzaCIsImdldEhhc2giLCJmcmFnbWVudCIsIlN0cmluZyIsIk9iamVjdCIsImFzc2lnbiIsInNpbGVudGx5Iiwid2luZG93IiwicmVtb3ZlRXZlbnRMaXN0ZW5lciIsImV2ZW50VHlwZSIsImhhc2hDaGFuZ2VMaXN0ZW5lciIsImxvY2F0aW9uIiwic2V0VGltZW91dCIsImFkZEV2ZW50TGlzdGVuZXIiLCJmcmFnbWVudENoYW5nZUhhbmRsZXIiLCJmcmFnbWVudENoYW5nZUhhbmRsZXJzIiwicHVzaCIsImluZGV4IiwiaW5kZXhPZiIsInN0YXJ0IiwiZGVsZXRlQ291bnQiLCJzcGxpY2UiLCJkZWZpbmVQcm9wZXJ0eSIsIkZSQUdNRU5UIiwiZ2V0Iiwic2V0IiwiSEFTSENIQU5HRV9FVkVOVF9UWVBFIiwiZXZlbnQiLCJmb3JFYWNoIiwic3Vic3RyaW5nIl0sInJhbmdlTWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OyIsIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7Ozs7SUFLZ0JBLFdBQVc7ZUFBWEE7O0lBa0NBQyxpQkFBaUI7ZUFBakJBOztJQUpBQyxnQkFBZ0I7ZUFBaEJBOztJQWhCQUMsV0FBVztlQUFYQTs7O3lCQWpCUzswQkFDYTtBQUUvQixTQUFTSDtJQUNkLElBQU1JLE9BQU9DLFdBQ1BDLFdBQVcsSUFBSUMsT0FBT0gsT0FBUSxHQUFHO0lBRXZDSSxPQUFPQyxNQUFNLENBQUNILFVBQVU7UUFDdEJOLGFBQUFBO1FBQ0FHLGFBQUFBO1FBQ0FELGtCQUFBQTtRQUNBRCxtQkFBQUE7SUFDRjtJQUVBLE9BQU9LO0FBQ1Q7QUFFTyxTQUFTSCxZQUFZRyxRQUFRO1FBQUVJLFdBQUFBLGlFQUFXO0lBQy9DLElBQU1OLE9BQU9FLFVBQVcsR0FBRztJQUUzQixJQUFJSSxVQUFVO1FBQ1pDLE9BQU9DLG1CQUFtQixDQUFDQyxXQUFXQztJQUN4QztJQUVBSCxPQUFPSSxRQUFRLENBQUNYLElBQUksR0FBR0E7SUFFdkIsSUFBSU0sVUFBVTtRQUNaTSxXQUFXO1lBQ1RMLE9BQU9NLGdCQUFnQixDQUFDSixXQUFXQztRQUNyQyxHQUFHO0lBQ0w7QUFDRjtBQUVPLFNBQVNaLGlCQUFpQmdCLHFCQUFxQjtJQUNwREMsdUJBQXVCQyxJQUFJLENBQUNGO0FBQzlCO0FBRU8sU0FBU2pCLGtCQUFrQmlCLHFCQUFxQjtJQUNyRCxJQUFNRyxRQUFRRix1QkFBdUJHLE9BQU8sQ0FBQ0o7SUFFN0MsSUFBSUcsUUFBUSxDQUFDLEdBQUc7UUFDZCxJQUFNRSxRQUFRRixPQUNSRyxjQUFjO1FBRXBCTCx1QkFBdUJNLE1BQU0sQ0FBQ0YsT0FBT0M7SUFDdkM7QUFDRjtBQUVBaEIsT0FBT2tCLGNBQWMsQ0FBQ2YsUUFBUWdCLG1CQUFRLEVBQUU7SUFDdENDLEtBQUssU0FBTEE7UUFDRSxJQUFNdEIsV0FBV047UUFFakIsT0FBT007SUFDVDtJQUVBdUIsS0FBSyxTQUFMQSxJQUFjdkIsUUFBUTtRQUNwQixJQUFNSSxXQUFXO1FBRWpCUCxZQUFZRyxVQUFVSTtJQUN4QjtBQUNGO0FBRUEsSUFBTUcsWUFBWWlCLGlDQUFxQixFQUNqQ1gseUJBQXlCLEVBQUU7QUFFakNSLE9BQU9NLGdCQUFnQixDQUFDSixXQUFXQztBQUVuQyxTQUFTQSxtQkFBbUJpQixLQUFLO0lBQy9CLElBQU0zQixPQUFPQyxXQUNQQyxXQUFXRixNQUFPLEdBQUc7SUFFM0JlLHVCQUF1QmEsT0FBTyxDQUFDLFNBQUNkO1FBQzlCQSxzQkFBc0JhLE9BQU96QjtJQUMvQjtBQUNGO0FBRUEsU0FBU0Q7SUFDUCxJQUFNLEFBQUVVLFdBQWFKLE9BQWJJO0lBRVIsSUFBSSxBQUFFWCxPQUFTVyxTQUFUWDtJQUVOLElBQU1tQixRQUFRO0lBRWRuQixPQUFPQSxLQUFLNkIsU0FBUyxDQUFDVjtJQUV0QixPQUFPbkI7QUFDVCJ9
|
|
137
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/fragmented.js"],"sourcesContent":["\"use strict\";\n\nimport { HASHCHANGE_EVENT_TYPE } from \"./eventTypes\";\nimport { HASH, FRAGMENT, EMPTY_STRING } from \"./constants\";\n\nexport function getFragment() {\n  const hash = getHash(),\n        fragment = new String(hash);  ///\n\n  Object.assign(fragment, {\n    getFragment,\n    setFragment,\n    resetFragment,\n    onFragmentChange,\n    offFragmentChange\n  });\n\n  return fragment;\n}\n\nexport function setFragment(fragment, silently = true) {\n  if (silently) {\n    window.removeEventListener(eventType, hashChangeListener);\n  }\n\n  const hash = fragment;  ///\n\n  window.location.hash = hash;\n\n  if (silently) {\n    setTimeout(() => {\n      window.addEventListener(eventType, hashChangeListener);\n    }, 0);\n  }\n}\n\nexport function resetFragment(silently = true) {\n  if (silently) {\n    window.removeEventListener(eventType, hashChangeListener);\n  }\n\n  let { href } = location;\n\n  const index = href.indexOf(HASH);\n\n  if (index !== -1) {\n    const start = 0,\n          end = index;  ///\n\n    href = href.substring(start, end); ///\n\n    history.pushState({}, EMPTY_STRING, href);\n  }\n\n  if (silently) {\n    setTimeout(() => {\n      window.addEventListener(eventType, hashChangeListener);\n    }, 0);\n  }\n}\n\nexport function onFragmentChange(fragmentChangeHandler, element = this) {\n  addFragmentChangeEventListener(fragmentChangeHandler, element);\n}\n\nexport function offFragmentChange(fragmentChangeHandler, element = this) {\n  removeFragmentChangeEventListener(fragmentChangeHandler, element);\n}\n\nObject.defineProperty(globalThis, FRAGMENT, {\n  get: function() {\n    const fragment = getFragment();\n\n    return fragment;\n  },\n\n  set: function(fragment) {\n    const silently = false;\n\n    setFragment(fragment, silently);\n  }\n});\n\nconst eventType = HASHCHANGE_EVENT_TYPE,\n      fragmentChangeEventListeners = [];\n\nwindow.addEventListener(eventType, hashChangeListener);\n\nfunction getHash() {\n  const { location } = window;\n\n  let { hash } = location;\n\n  const start = 1;\n\n  hash = hash.substring(start);\n\n  return hash;\n}\n\nfunction hashChangeListener(event) {\n  const hash = getHash(),\n        element = window, ///\n        fragment = hash;  ///\n\n  callFragmentChangeHandlers(event, element, fragment);\n}\n\nfunction callFragmentChangeHandlers(event, element, fragment) {\n  fragmentChangeEventListeners.forEach((fragmentChangeEventListener) => {\n    const { fragmentChangeHandler, element: fragmentChangeHandlerElement } = fragmentChangeEventListener; ///\n\n    fragmentChangeHandler.call(fragmentChangeHandlerElement, event, element, fragment);\n  });\n}\n\nfunction addFragmentChangeEventListener(fragmentChangeHandler, element) {\n  const fragmentChangeEventListener = createFragmentChangeEventListener(fragmentChangeHandler, element);\n\n  fragmentChangeEventListeners.push(fragmentChangeEventListener);\n\n  return fragmentChangeEventListener;\n}\n\nfunction removeFragmentChangeEventListener(fragmentChangeHandler, element) {\n  const fragmentChangeEventListener = findFragmentChangeEventListener(fragmentChangeHandler, element),\n        index = fragmentChangeEventListeners.indexOf(fragmentChangeEventListener),\n        start = index,  ///\n        deleteCount = 1;\n\n  fragmentChangeEventListeners.splice(start, deleteCount);\n\n  return fragmentChangeEventListener;\n}\n\nfunction createFragmentChangeEventListener(fragmentChangeHandler, element) {\n  let fragmentChangeEventListener;\n\n  fragmentChangeEventListener = () => {}; ///\n\n  Object.assign(fragmentChangeEventListener, {\n    element,\n    fragmentChangeHandler\n  });\n\n  return fragmentChangeEventListener;\n}\n\nfunction findFragmentChangeEventListener(fragmentChangeHandler, element) {\n  const fragmentChangeEventListener = fragmentChangeEventListeners.find((fragmentChangeEventListener) => {\n    if ((fragmentChangeEventListener.element === element) && (fragmentChangeEventListener.fragmentChangeHandler === fragmentChangeHandler)) {\n      return true;\n    }\n  });\n\n  return fragmentChangeEventListener;\n}\n"],"names":["getFragment","offFragmentChange","onFragmentChange","resetFragment","setFragment","hash","getHash","fragment","String","Object","assign","silently","window","removeEventListener","eventType","hashChangeListener","location","setTimeout","addEventListener","href","index","indexOf","HASH","start","end","substring","history","pushState","EMPTY_STRING","fragmentChangeHandler","element","addFragmentChangeEventListener","removeFragmentChangeEventListener","defineProperty","globalThis","FRAGMENT","get","set","HASHCHANGE_EVENT_TYPE","fragmentChangeEventListeners","event","callFragmentChangeHandlers","forEach","fragmentChangeEventListener","fragmentChangeHandlerElement","call","createFragmentChangeEventListener","push","findFragmentChangeEventListener","deleteCount","splice","find"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"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"}
|
package/lib/index.js
CHANGED
|
@@ -18,10 +18,13 @@ _export(exports, {
|
|
|
18
18
|
onFragmentChange: function() {
|
|
19
19
|
return _fragmented.onFragmentChange;
|
|
20
20
|
},
|
|
21
|
+
resetFragment: function() {
|
|
22
|
+
return _fragmented.resetFragment;
|
|
23
|
+
},
|
|
21
24
|
setFragment: function() {
|
|
22
25
|
return _fragmented.setFragment;
|
|
23
26
|
}
|
|
24
27
|
});
|
|
25
28
|
var _fragmented = require("./fragmented");
|
|
26
29
|
|
|
27
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJcInVzZSBzdHJpY3RcIjtcblxuaW1wb3J0IFwiLi9mcmFnbWVudGVkXCI7XG5cbmV4cG9ydCB7IGdldEZyYWdtZW50LCBzZXRGcmFnbWVudCwgcmVzZXRGcmFnbWVudCwgb25GcmFnbWVudENoYW5nZSwgb2ZmRnJhZ21lbnRDaGFuZ2UgfSBmcm9tIFwiLi9mcmFnbWVudGVkXCI7XG5cbiJdLCJuYW1lcyI6WyJnZXRGcmFnbWVudCIsIm9mZkZyYWdtZW50Q2hhbmdlIiwib25GcmFnbWVudENoYW5nZSIsInJlc2V0RnJhZ21lbnQiLCJzZXRGcmFnbWVudCJdLCJyYW5nZU1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7IiwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7OztJQUlTQSxXQUFXO2VBQVhBLHVCQUFXOztJQUFnREMsaUJBQWlCO2VBQWpCQSw2QkFBaUI7O0lBQW5DQyxnQkFBZ0I7ZUFBaEJBLDRCQUFnQjs7SUFBL0JDLGFBQWE7ZUFBYkEseUJBQWE7O0lBQTFCQyxXQUFXO2VBQVhBLHVCQUFXOzs7MEJBRjFCIn0=
|
package/package.json
CHANGED
package/src/constants.js
CHANGED
package/src/fragmented.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
import { FRAGMENT } from "./constants";
|
|
4
3
|
import { HASHCHANGE_EVENT_TYPE } from "./eventTypes";
|
|
4
|
+
import { HASH, FRAGMENT, EMPTY_STRING } from "./constants";
|
|
5
5
|
|
|
6
6
|
export function getFragment() {
|
|
7
7
|
const hash = getHash(),
|
|
@@ -10,6 +10,7 @@ export function getFragment() {
|
|
|
10
10
|
Object.assign(fragment, {
|
|
11
11
|
getFragment,
|
|
12
12
|
setFragment,
|
|
13
|
+
resetFragment,
|
|
13
14
|
onFragmentChange,
|
|
14
15
|
offFragmentChange
|
|
15
16
|
});
|
|
@@ -18,12 +19,12 @@ export function getFragment() {
|
|
|
18
19
|
}
|
|
19
20
|
|
|
20
21
|
export function setFragment(fragment, silently = true) {
|
|
21
|
-
const hash = fragment; ///
|
|
22
|
-
|
|
23
22
|
if (silently) {
|
|
24
23
|
window.removeEventListener(eventType, hashChangeListener);
|
|
25
24
|
}
|
|
26
25
|
|
|
26
|
+
const hash = fragment; ///
|
|
27
|
+
|
|
27
28
|
window.location.hash = hash;
|
|
28
29
|
|
|
29
30
|
if (silently) {
|
|
@@ -33,22 +34,40 @@ export function setFragment(fragment, silently = true) {
|
|
|
33
34
|
}
|
|
34
35
|
}
|
|
35
36
|
|
|
36
|
-
export function
|
|
37
|
-
|
|
38
|
-
|
|
37
|
+
export function resetFragment(silently = true) {
|
|
38
|
+
if (silently) {
|
|
39
|
+
window.removeEventListener(eventType, hashChangeListener);
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
let { href } = location;
|
|
39
43
|
|
|
40
|
-
|
|
41
|
-
const index = fragmentChangeHandlers.indexOf(fragmentChangeHandler);
|
|
44
|
+
const index = href.indexOf(HASH);
|
|
42
45
|
|
|
43
|
-
if (index
|
|
44
|
-
const start =
|
|
45
|
-
|
|
46
|
+
if (index !== -1) {
|
|
47
|
+
const start = 0,
|
|
48
|
+
end = index; ///
|
|
46
49
|
|
|
47
|
-
|
|
50
|
+
href = href.substring(start, end); ///
|
|
51
|
+
|
|
52
|
+
history.pushState({}, EMPTY_STRING, href);
|
|
48
53
|
}
|
|
54
|
+
|
|
55
|
+
if (silently) {
|
|
56
|
+
setTimeout(() => {
|
|
57
|
+
window.addEventListener(eventType, hashChangeListener);
|
|
58
|
+
}, 0);
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
export function onFragmentChange(fragmentChangeHandler, element = this) {
|
|
63
|
+
addFragmentChangeEventListener(fragmentChangeHandler, element);
|
|
49
64
|
}
|
|
50
65
|
|
|
51
|
-
|
|
66
|
+
export function offFragmentChange(fragmentChangeHandler, element = this) {
|
|
67
|
+
removeFragmentChangeEventListener(fragmentChangeHandler, element);
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
Object.defineProperty(globalThis, FRAGMENT, {
|
|
52
71
|
get: function() {
|
|
53
72
|
const fragment = getFragment();
|
|
54
73
|
|
|
@@ -63,27 +82,76 @@ Object.defineProperty(window, FRAGMENT, {
|
|
|
63
82
|
});
|
|
64
83
|
|
|
65
84
|
const eventType = HASHCHANGE_EVENT_TYPE,
|
|
66
|
-
|
|
85
|
+
fragmentChangeEventListeners = [];
|
|
67
86
|
|
|
68
87
|
window.addEventListener(eventType, hashChangeListener);
|
|
69
88
|
|
|
89
|
+
function getHash() {
|
|
90
|
+
const { location } = window;
|
|
91
|
+
|
|
92
|
+
let { hash } = location;
|
|
93
|
+
|
|
94
|
+
const start = 1;
|
|
95
|
+
|
|
96
|
+
hash = hash.substring(start);
|
|
97
|
+
|
|
98
|
+
return hash;
|
|
99
|
+
}
|
|
100
|
+
|
|
70
101
|
function hashChangeListener(event) {
|
|
71
102
|
const hash = getHash(),
|
|
103
|
+
element = window, ///
|
|
72
104
|
fragment = hash; ///
|
|
73
105
|
|
|
74
|
-
|
|
75
|
-
|
|
106
|
+
callFragmentChangeHandlers(event, element, fragment);
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
function callFragmentChangeHandlers(event, element, fragment) {
|
|
110
|
+
fragmentChangeEventListeners.forEach((fragmentChangeEventListener) => {
|
|
111
|
+
const { fragmentChangeHandler, element: fragmentChangeHandlerElement } = fragmentChangeEventListener; ///
|
|
112
|
+
|
|
113
|
+
fragmentChangeHandler.call(fragmentChangeHandlerElement, event, element, fragment);
|
|
76
114
|
});
|
|
77
115
|
}
|
|
78
116
|
|
|
79
|
-
function
|
|
80
|
-
const
|
|
117
|
+
function addFragmentChangeEventListener(fragmentChangeHandler, element) {
|
|
118
|
+
const fragmentChangeEventListener = createFragmentChangeEventListener(fragmentChangeHandler, element);
|
|
81
119
|
|
|
82
|
-
|
|
120
|
+
fragmentChangeEventListeners.push(fragmentChangeEventListener);
|
|
83
121
|
|
|
84
|
-
|
|
122
|
+
return fragmentChangeEventListener;
|
|
123
|
+
}
|
|
85
124
|
|
|
86
|
-
|
|
125
|
+
function removeFragmentChangeEventListener(fragmentChangeHandler, element) {
|
|
126
|
+
const fragmentChangeEventListener = findFragmentChangeEventListener(fragmentChangeHandler, element),
|
|
127
|
+
index = fragmentChangeEventListeners.indexOf(fragmentChangeEventListener),
|
|
128
|
+
start = index, ///
|
|
129
|
+
deleteCount = 1;
|
|
87
130
|
|
|
88
|
-
|
|
89
|
-
|
|
131
|
+
fragmentChangeEventListeners.splice(start, deleteCount);
|
|
132
|
+
|
|
133
|
+
return fragmentChangeEventListener;
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
function createFragmentChangeEventListener(fragmentChangeHandler, element) {
|
|
137
|
+
let fragmentChangeEventListener;
|
|
138
|
+
|
|
139
|
+
fragmentChangeEventListener = () => {}; ///
|
|
140
|
+
|
|
141
|
+
Object.assign(fragmentChangeEventListener, {
|
|
142
|
+
element,
|
|
143
|
+
fragmentChangeHandler
|
|
144
|
+
});
|
|
145
|
+
|
|
146
|
+
return fragmentChangeEventListener;
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
function findFragmentChangeEventListener(fragmentChangeHandler, element) {
|
|
150
|
+
const fragmentChangeEventListener = fragmentChangeEventListeners.find((fragmentChangeEventListener) => {
|
|
151
|
+
if ((fragmentChangeEventListener.element === element) && (fragmentChangeEventListener.fragmentChangeHandler === fragmentChangeHandler)) {
|
|
152
|
+
return true;
|
|
153
|
+
}
|
|
154
|
+
});
|
|
155
|
+
|
|
156
|
+
return fragmentChangeEventListener;
|
|
157
|
+
}
|
package/src/index.js
CHANGED