UNPKG

react-xrplayer

Version:

An excellent xr player for react

112 lines (90 loc) 3.3 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.player = player; exports.enableEffectContainer = enableEffectContainer; exports.setEffectData = setEffectData; exports.setGlobalVolume = setGlobalVolume; exports.setGlobalMuted = setGlobalMuted; function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } var ENABLE_EFFECT_CONTAINER = "ENABLE_EFFECT_CONTAINER"; var EFFECT_DATA = "EFFECT_DATA"; var VOLUME = "VOLUME"; var MUTED = "MUTED"; // 初始state中的数据 var initialState = { is_effect_displaying: false, effect_data: {}, volume: 0.9, muted: true }; //reducer, 根据action对state进行处理,返回新的state function player() { var state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : initialState; var action = arguments.length > 1 ? arguments[1] : undefined; switch (action.type) { case ENABLE_EFFECT_CONTAINER: return _objectSpread({}, state, { is_effect_displaying: action.payload }); case EFFECT_DATA: return _objectSpread({}, state, { effect_data: action.payload }); case VOLUME: return _objectSpread({}, state, { volume: action.payload }); case MUTED: return _objectSpread({}, state, { muted: action.payload }); default: return state; } } //actionCreator, 创建action对象 function enableEffectContainerAction(data) { return { payload: data, type: ENABLE_EFFECT_CONTAINER }; } function effectDataAction(data) { return { payload: data, type: EFFECT_DATA }; } function volumeAction(data) { return { payload: data, type: VOLUME }; } function mutedAction(data) { return { payload: data, type: MUTED }; } //在组件中调用的dispatch action的函数 function enableEffectContainer(enable) { return function (dispatch) { dispatch(enableEffectContainerAction(enable)); }; } function setEffectData(data) { return function (dispatch) { dispatch(effectDataAction(data)); }; } function setGlobalVolume(value) { return function (dispatch) { dispatch(volumeAction(value)); }; } function setGlobalMuted(muted) { return function (dispatch) { dispatch(mutedAction(muted)); }; }