This app provides monitoring and information features for the common freifunk user and the technical stuff of a freifunk community.
Code base is taken from a TUM Practical Course project and added here to see if Freifunk Altdorf can use it.
https://www.freifunk-altdorf.de
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
53 lines
1.4 KiB
53 lines
1.4 KiB
/** |
|
* Copyright (c) 2015-present, Facebook, Inc. |
|
* |
|
* This source code is licensed under the MIT license found in the |
|
* LICENSE file in the root directory of this source tree. |
|
* |
|
* @providesModule InteractionMixin |
|
* @flow |
|
*/ |
|
'use strict'; |
|
|
|
var InteractionManager = require('InteractionManager'); |
|
|
|
/** |
|
* This mixin provides safe versions of InteractionManager start/end methods |
|
* that ensures `clearInteractionHandle` is always called |
|
* once per start, even if the component is unmounted. |
|
*/ |
|
var InteractionMixin = { |
|
componentWillUnmount: function() { |
|
while (this._interactionMixinHandles.length) { |
|
InteractionManager.clearInteractionHandle( |
|
this._interactionMixinHandles.pop() |
|
); |
|
} |
|
}, |
|
|
|
_interactionMixinHandles: ([]: Array<number>), |
|
|
|
createInteractionHandle: function() { |
|
var handle = InteractionManager.createInteractionHandle(); |
|
this._interactionMixinHandles.push(handle); |
|
return handle; |
|
}, |
|
|
|
clearInteractionHandle: function(clearHandle: number) { |
|
InteractionManager.clearInteractionHandle(clearHandle); |
|
this._interactionMixinHandles = this._interactionMixinHandles.filter( |
|
handle => handle !== clearHandle |
|
); |
|
}, |
|
|
|
/** |
|
* Schedule work for after all interactions have completed. |
|
* |
|
* @param {function} callback |
|
*/ |
|
runAfterInteractions: function(callback: Function) { |
|
InteractionManager.runAfterInteractions(callback); |
|
}, |
|
}; |
|
|
|
module.exports = InteractionMixin;
|
|
|