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 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, and for deep linking.
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
- All that Fragmented does is create a global [`fragment`](https://github.com/djalbat/Fragmented/blob/master/es6/fragmented.js) variable, the value of which the application can get or set, and which also has `onFragmentChange` and `offFragmentChange` properties so that handlers can be registered and unregistered.
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
- There are no objects exported as such, you only need to import the package:
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
- Registering and un-registering change handlers:
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
- function fragmentChangeHandler() {
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 change 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 change handlers being invoked, you can to this with an additional `setFragment()` function as follows:
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"); // change handlers won't be invoked
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. Finally, 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.
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
- You can import these functions more conventionally if you think that destructuring the global `fragment` variable is too cute:
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 if you do not like the thought of a global `fragment` variable then you can refer to it as `window.fragment`.
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/constants.js
11
- var require_constants = __commonJS((exports) => {
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, "FRAGMENT", {
16
+ Object.defineProperty(exports, "HASHCHANGE_EVENT_TYPE", {
17
17
  enumerable: true,
18
18
  get: function() {
19
- return FRAGMENT;
19
+ return HASHCHANGE_EVENT_TYPE;
20
20
  }
21
21
  });
22
- var FRAGMENT = "fragment";
22
+ var HASHCHANGE_EVENT_TYPE = "hashchange";
23
23
  });
24
24
 
25
- // lib/eventTypes.js
26
- var require_eventTypes = __commonJS((exports) => {
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
- Object.defineProperty(exports, "HASHCHANGE_EVENT_TYPE", {
32
- enumerable: true,
33
- get: function() {
34
- return HASHCHANGE_EVENT_TYPE;
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 HASHCHANGE_EVENT_TYPE = "hashchange";
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
- fragmentChangeHandlers.push(fragmentChangeHandler);
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 index = fragmentChangeHandlers.indexOf(fragmentChangeHandler);
97
- if (index > -1) {
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(window, _constants.FRAGMENT, {
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 fragmentChangeHandlers = [];
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 location = window.location;
123
- var hash = location.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,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsic3JjL2NvbnN0YW50cy5qcyIsICJzcmMvZXZlbnRUeXBlcy5qcyIsICJzcmMvZnJhZ21lbnRlZC5qcyIsICJzcmMvaW5kZXguanMiLCAic3JjL2V4YW1wbGUuanMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIlwidXNlIHN0cmljdFwiO1xuXG5leHBvcnQgY29uc3QgRlJBR01FTlQgPSBcImZyYWdtZW50XCI7XG4iLCAiXCJ1c2Ugc3RyaWN0XCI7XG5cbmV4cG9ydCBjb25zdCBIQVNIQ0hBTkdFX0VWRU5UX1RZUEUgPSBcImhhc2hjaGFuZ2VcIjtcbiIsICJcInVzZSBzdHJpY3RcIjtcblxuaW1wb3J0IHsgRlJBR01FTlQgfSBmcm9tIFwiLi9jb25zdGFudHNcIjtcbmltcG9ydCB7IEhBU0hDSEFOR0VfRVZFTlRfVFlQRSB9IGZyb20gXCIuL2V2ZW50VHlwZXNcIjtcblxuZXhwb3J0IGZ1bmN0aW9uIGdldEZyYWdtZW50KCkge1xuICBjb25zdCBoYXNoID0gZ2V0SGFzaCgpLFxuICAgICAgICBmcmFnbWVudCA9IG5ldyBTdHJpbmcoaGFzaCk7ICAvLy9cblxuICBPYmplY3QuYXNzaWduKGZyYWdtZW50LCB7XG4gICAgZ2V0RnJhZ21lbnQsXG4gICAgc2V0RnJhZ21lbnQsXG4gICAgb25GcmFnbWVudENoYW5nZSxcbiAgICBvZmZGcmFnbWVudENoYW5nZVxuICB9KTtcblxuICByZXR1cm4gZnJhZ21lbnQ7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBzZXRGcmFnbWVudChmcmFnbWVudCwgc2lsZW50bHkgPSB0cnVlKSB7XG4gIGNvbnN0IGhhc2ggPSBmcmFnbWVudDsgIC8vL1xuXG4gIGlmIChzaWxlbnRseSkge1xuICAgIHdpbmRvdy5yZW1vdmVFdmVudExpc3RlbmVyKGV2ZW50VHlwZSwgaGFzaENoYW5nZUxpc3RlbmVyKTtcbiAgfVxuXG4gIHdpbmRvdy5sb2NhdGlvbi5oYXNoID0gaGFzaDtcblxuICBpZiAoc2lsZW50bHkpIHtcbiAgICBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgIHdpbmRvdy5hZGRFdmVudExpc3RlbmVyKGV2ZW50VHlwZSwgaGFzaENoYW5nZUxpc3RlbmVyKTtcbiAgICB9LCAwKTtcbiAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gb25GcmFnbWVudENoYW5nZShmcmFnbWVudENoYW5nZUhhbmRsZXIpIHtcbiAgZnJhZ21lbnRDaGFuZ2VIYW5kbGVycy5wdXNoKGZyYWdtZW50Q2hhbmdlSGFuZGxlcik7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBvZmZGcmFnbWVudENoYW5nZShmcmFnbWVudENoYW5nZUhhbmRsZXIpIHtcbiAgY29uc3QgaW5kZXggPSBmcmFnbWVudENoYW5nZUhhbmRsZXJzLmluZGV4T2YoZnJhZ21lbnRDaGFuZ2VIYW5kbGVyKTtcblxuICBpZiAoaW5kZXggPiAtMSkge1xuICAgIGNvbnN0IHN0YXJ0ID0gaW5kZXgsICAvLy9cbiAgICAgICAgICBkZWxldGVDb3VudCA9IDE7XG5cbiAgICBmcmFnbWVudENoYW5nZUhhbmRsZXJzLnNwbGljZShzdGFydCwgZGVsZXRlQ291bnQpO1xuICB9XG59XG5cbk9iamVjdC5kZWZpbmVQcm9wZXJ0eSh3aW5kb3csIEZSQUdNRU5ULCB7XG4gIGdldDogZnVuY3Rpb24oKSB7XG4gICAgY29uc3QgZnJhZ21lbnQgPSBnZXRGcmFnbWVudCgpO1xuXG4gICAgcmV0dXJuIGZyYWdtZW50O1xuICB9LFxuXG4gIHNldDogZnVuY3Rpb24oZnJhZ21lbnQpIHtcbiAgICBjb25zdCBzaWxlbnRseSA9IGZhbHNlO1xuXG4gICAgc2V0RnJhZ21lbnQoZnJhZ21lbnQsIHNpbGVudGx5KTtcbiAgfVxufSk7XG5cbmNvbnN0IGV2ZW50VHlwZSA9IEhBU0hDSEFOR0VfRVZFTlRfVFlQRSxcbiAgICAgIGZyYWdtZW50Q2hhbmdlSGFuZGxlcnMgPSBbXTtcblxud2luZG93LmFkZEV2ZW50TGlzdGVuZXIoZXZlbnRUeXBlLCBoYXNoQ2hhbmdlTGlzdGVuZXIpO1xuXG5mdW5jdGlvbiBoYXNoQ2hhbmdlTGlzdGVuZXIoZXZlbnQpIHtcbiAgY29uc3QgaGFzaCA9IGdldEhhc2goKSxcbiAgICAgICAgZnJhZ21lbnQgPSBoYXNoOyAgLy8vXG5cbiAgZnJhZ21lbnRDaGFuZ2VIYW5kbGVycy5mb3JFYWNoKChmcmFnbWVudENoYW5nZUhhbmRsZXIpID0+IHtcbiAgICBmcmFnbWVudENoYW5nZUhhbmRsZXIoZXZlbnQsIGZyYWdtZW50KTtcbiAgfSk7XG59XG5cbmZ1bmN0aW9uIGdldEhhc2goKSB7XG4gIGNvbnN0IHsgbG9jYXRpb24gfSA9IHdpbmRvdztcblxuICBsZXQgeyBoYXNoIH0gPSBsb2NhdGlvbjtcblxuICBjb25zdCBzdGFydCA9IDE7XG5cbiAgaGFzaCA9IGhhc2guc3Vic3RyaW5nKHN0YXJ0KTtcblxuICByZXR1cm4gaGFzaDtcbn0iLCAiXCJ1c2Ugc3RyaWN0XCI7XG5cbmltcG9ydCBcIi4vZnJhZ21lbnRlZFwiO1xuXG5leHBvcnQgeyBzZXRGcmFnbWVudCwgZ2V0RnJhZ21lbnQsIG9uRnJhZ21lbnRDaGFuZ2UsIG9mZkZyYWdtZW50Q2hhbmdlIH0gZnJvbSBcIi4vZnJhZ21lbnRlZFwiO1xuXG4iLCAiXCJ1c2Ugc3RyaWN0XCI7XG5cbmltcG9ydCBcIi4vaW5kZXhcIjsgLy8vXG5cbmNvbnN0IHsgb25GcmFnbWVudENoYW5nZSwgb2ZmRnJhZ21lbnRDaGFuZ2UgfSA9IGZyYWdtZW50O1xuXG5vbkZyYWdtZW50Q2hhbmdlKGZyYWdtZW50Q2hhbmdlSGFuZGxlcik7XG5cbmNvbnNvbGUubG9nKGZyYWdtZW50KVxuXG5mcmFnbWVudCA9IFwidGVzdFwiO1xuXG4vLyBvZmZGcmFnbWVudENoYW5nZShmcmFnbWVudENoYW5nZUhhbmRsZXIpO1xuXG5mdW5jdGlvbiBmcmFnbWVudENoYW5nZUhhbmRsZXIoKSB7XG4gIGNvbnNvbGUubG9nKGZyYWdtZW50KVxufVxuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7OztBQUFBOzs7OzttQ0FFYSxZQUFBOzs7ZUFBQTs7O0FBQU4sUUFBTSxXQUFXOzs7O0FDRnhCOzs7OzttQ0FFYSx5QkFBQTs7O2VBQUE7OztBQUFOLFFBQU0sd0JBQXdCOzs7O0FDRnJDOzs7Ozs7Ozs7Ozs7O01BS2dCLGFBQVcsV0FBQTtlQUFYOztNQWtDQSxtQkFBaUIsV0FBQTtlQUFqQjs7TUFKQSxrQkFBZ0IsV0FBQTtlQUFoQjs7TUFoQkEsYUFBVyxXQUFBO2VBQVg7Ozs7O0FBZFQsMkJBQVM7QUFDZCxVQUFNLE9BQU8sV0FDUCxZQUFXLElBQUksT0FBTztBQUU1QixhQUFPLE9BQU8sV0FBVTtRQUN0QjtRQUNBO1FBQ0E7UUFDQTs7QUFHRixhQUFPOztBQUdGLHlCQUFxQixXQUFRO1VBQUUsV0FBQSxVQUFBLFNBQUEsS0FBQSxVQUFBLE9BQUEsU0FBQSxVQUFBLEtBQVc7QUFDL0MsVUFBTSxPQUFPO0FBRWIsVUFBSSxVQUFVO0FBQ1osZUFBTyxvQkFBb0IsV0FBVzs7QUFHeEMsYUFBTyxTQUFTLE9BQU87QUFFdkIsVUFBSSxVQUFVO0FBQ1osbUJBQVcsV0FBQTtBQUNULGlCQUFPLGlCQUFpQixXQUFXO1dBQ2xDOzs7QUFJQSw4QkFBMEIsdUJBQXFCO0FBQ3BELDZCQUF1QixLQUFLOztBQUd2QiwrQkFBMkIsdUJBQXFCO0FBQ3JELFVBQU0sUUFBUSx1QkFBdUIsUUFBUTtBQUU3QyxVQUFJLFFBQVEsSUFBSTtBQUNkLFlBQU0sUUFBUSxPQUNSLGNBQWM7QUFFcEIsK0JBQXVCLE9BQU8sT0FBTzs7O0FBSXpDLFdBQU8sZUFBZSxRQUFRLFdBQUEsVUFBVTtNQUN0QyxLQUFLLGVBQUw7QUFDRSxZQUFNLFlBQVc7QUFFakIsZUFBTzs7TUFHVCxLQUFLLGFBQVMsV0FBUTtBQUNwQixZQUFNLFdBQVc7QUFFakIsb0JBQVksV0FBVTs7O0FBSTFCLFFBQU0sWUFBWSxZQUFBO0FBQWxCLFFBQ00seUJBQXlCO0FBRS9CLFdBQU8saUJBQWlCLFdBQVc7QUFFbkMsZ0NBQTRCLE9BQUs7QUFDL0IsVUFBTSxPQUFPLFdBQ1AsWUFBVztBQUVqQiw2QkFBdUIsUUFBUSxTQUFDLHVCQUFBO0FBQzlCLDhCQUFzQixPQUFPOzs7QUFJakMsdUJBQVM7QUFDUCxVQUFRLFdBQWEsT0FBYjtBQUVSLFVBQU0sT0FBUyxTQUFUO0FBRU4sVUFBTSxRQUFRO0FBRWQsYUFBTyxLQUFLLFVBQVU7QUFFdEIsYUFBTzs7Ozs7QUN2RlQ7Ozs7Ozs7Ozs7Ozs7TUFJc0IsYUFBVyxXQUFBO2VBQVgsWUFBQTs7TUFBK0IsbUJBQWlCLFdBQUE7ZUFBakIsWUFBQTs7TUFBbEIsa0JBQWdCLFdBQUE7ZUFBaEIsWUFBQTs7TUFBMUIsYUFBVyxXQUFBO2VBQVgsWUFBQTs7Ozs7OztBQ0pUOzs7Ozs7QUFJQSxRQUFRLG1CQUF3QyxTQUF4QztBQUFSLFFBQTBCLG9CQUFzQixTQUF0QjtBQUUxQixxQkFBaUI7QUFFakIsWUFBUSxJQUFJO0FBRVosZUFBVztBQUlYLHFDQUFTO0FBQ1AsY0FBUSxJQUFJOzs7IiwKICAibmFtZXMiOiBbXQp9Cg==
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
- Object.defineProperty(exports, "FRAGMENT", {
6
- enumerable: true,
7
- get: function() {
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9jb25zdGFudHMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiXCJ1c2Ugc3RyaWN0XCI7XG5cbmV4cG9ydCBjb25zdCBGUkFHTUVOVCA9IFwiZnJhZ21lbnRcIjtcbiJdLCJuYW1lcyI6WyJGUkFHTUVOVCJdLCJyYW5nZU1hcHBpbmdzIjoiOzs7Ozs7Ozs7OyIsIm1hcHBpbmdzIjoiQUFBQTs7OzsrQkFFYUE7OztlQUFBQTs7O0FBQU4sSUFBTUEsV0FBVyJ9
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
- fragmentChangeHandlers.push(fragmentChangeHandler);
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 index = fragmentChangeHandlers.indexOf(fragmentChangeHandler);
55
- if (index > -1) {
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(window, _constants.FRAGMENT, {
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, fragmentChangeHandlers = [];
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 location = window.location;
80
- var hash = location.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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJcInVzZSBzdHJpY3RcIjtcblxuaW1wb3J0IFwiLi9mcmFnbWVudGVkXCI7XG5cbmV4cG9ydCB7IHNldEZyYWdtZW50LCBnZXRGcmFnbWVudCwgb25GcmFnbWVudENoYW5nZSwgb2ZmRnJhZ21lbnRDaGFuZ2UgfSBmcm9tIFwiLi9mcmFnbWVudGVkXCI7XG5cbiJdLCJuYW1lcyI6WyJnZXRGcmFnbWVudCIsIm9mZkZyYWdtZW50Q2hhbmdlIiwib25GcmFnbWVudENoYW5nZSIsInNldEZyYWdtZW50Il0sInJhbmdlTWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OzsiLCJtYXBwaW5ncyI6IkFBQUE7Ozs7Ozs7Ozs7O0lBSXNCQSxXQUFXO2VBQVhBLHVCQUFXOztJQUFvQkMsaUJBQWlCO2VBQWpCQSw2QkFBaUI7O0lBQW5DQyxnQkFBZ0I7ZUFBaEJBLDRCQUFnQjs7SUFBMUNDLFdBQVc7ZUFBWEEsdUJBQVc7OzswQkFGYiJ9
30
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJcInVzZSBzdHJpY3RcIjtcblxuaW1wb3J0IFwiLi9mcmFnbWVudGVkXCI7XG5cbmV4cG9ydCB7IGdldEZyYWdtZW50LCBzZXRGcmFnbWVudCwgcmVzZXRGcmFnbWVudCwgb25GcmFnbWVudENoYW5nZSwgb2ZmRnJhZ21lbnRDaGFuZ2UgfSBmcm9tIFwiLi9mcmFnbWVudGVkXCI7XG5cbiJdLCJuYW1lcyI6WyJnZXRGcmFnbWVudCIsIm9mZkZyYWdtZW50Q2hhbmdlIiwib25GcmFnbWVudENoYW5nZSIsInJlc2V0RnJhZ21lbnQiLCJzZXRGcmFnbWVudCJdLCJyYW5nZU1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7IiwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7OztJQUlTQSxXQUFXO2VBQVhBLHVCQUFXOztJQUFnREMsaUJBQWlCO2VBQWpCQSw2QkFBaUI7O0lBQW5DQyxnQkFBZ0I7ZUFBaEJBLDRCQUFnQjs7SUFBL0JDLGFBQWE7ZUFBYkEseUJBQWE7O0lBQTFCQyxXQUFXO2VBQVhBLHVCQUFXOzs7MEJBRjFCIn0=
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "fragmented",
3
3
  "author": "James Smith",
4
- "version": "3.1.3",
4
+ "version": "3.1.5",
5
5
  "license": "MIT, Anti-996",
6
6
  "homepage": "https://github.com/djalbat/fragmented",
7
7
  "description": "Relates to URL hash fragments.",
package/src/constants.js CHANGED
@@ -1,3 +1,5 @@
1
1
  "use strict";
2
2
 
3
+ export const HASH = "#";
3
4
  export const FRAGMENT = "fragment";
5
+ export const EMPTY_STRING = "";
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 onFragmentChange(fragmentChangeHandler) {
37
- fragmentChangeHandlers.push(fragmentChangeHandler);
38
- }
37
+ export function resetFragment(silently = true) {
38
+ if (silently) {
39
+ window.removeEventListener(eventType, hashChangeListener);
40
+ }
41
+
42
+ let { href } = location;
39
43
 
40
- export function offFragmentChange(fragmentChangeHandler) {
41
- const index = fragmentChangeHandlers.indexOf(fragmentChangeHandler);
44
+ const index = href.indexOf(HASH);
42
45
 
43
- if (index > -1) {
44
- const start = index, ///
45
- deleteCount = 1;
46
+ if (index !== -1) {
47
+ const start = 0,
48
+ end = index; ///
46
49
 
47
- fragmentChangeHandlers.splice(start, deleteCount);
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
- Object.defineProperty(window, FRAGMENT, {
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
- fragmentChangeHandlers = [];
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
- fragmentChangeHandlers.forEach((fragmentChangeHandler) => {
75
- fragmentChangeHandler(event, fragment);
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 getHash() {
80
- const { location } = window;
117
+ function addFragmentChangeEventListener(fragmentChangeHandler, element) {
118
+ const fragmentChangeEventListener = createFragmentChangeEventListener(fragmentChangeHandler, element);
81
119
 
82
- let { hash } = location;
120
+ fragmentChangeEventListeners.push(fragmentChangeEventListener);
83
121
 
84
- const start = 1;
122
+ return fragmentChangeEventListener;
123
+ }
85
124
 
86
- hash = hash.substring(start);
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
- return hash;
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
@@ -2,5 +2,5 @@
2
2
 
3
3
  import "./fragmented";
4
4
 
5
- export { setFragment, getFragment, onFragmentChange, offFragmentChange } from "./fragmented";
5
+ export { getFragment, setFragment, resetFragment, onFragmentChange, offFragmentChange } from "./fragmented";
6
6