media_player_client/src/store/index.ts

1042 lines
31 KiB
TypeScript
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

import { ConnectTableEntity } from "src/entities/ConnectTableEntity";
import {
PollingEntity,
PollingTreeItemEntity,
} from "src/entities/PollingEntity";
import { store } from "quasar/wrappers";
import { ModeEntity, ModeTreeItemEntity } from "src/entities/ModeEntity";
import { WindowOpenNotifyEntity } from "src/entities/MultimediaWindowEntity";
import { PlanEntity, PlanTreeItemEntity } from "src/entities/PlanEntity";
import {
SignalSourceEntity,
SignalSourceTreeItemEntity,
} from "src/entities/SignalSourceEntity";
import { InjectionKey, reactive } from "vue";
import {
createStore,
Store as VuexStore,
useStore as vuexUseStore,
} from "vuex";
import { EDeviceAttribute } from "src/entities/EDeviceAttribute";
// import example from './module-example'
// import { ExampleStateInterface } from './module-example/state';
/*
* If not building with SSR mode, you can
* directly export the Store instantiation;
*
* The function below can be async too; either use
* async/await or return a Promise which resolves
* with the Store instance.
*/
export class CustomDefines {
is_custom_isv = false;
function_output_board = false;
function_center_control = false;
function_mirroring_output = false;
}
export interface IWuJieEventBus {
$on(event: string, fn: Function): IWuJieEventBus;
/** 任何$emit都会导致监听函数触发第一个参数为事件名后续的参数为$emit的参数 */
$onAll(fn: (event: string, ...args: Array<any>) => any): IWuJieEventBus;
$once(event: string, fn: Function): void;
$off(event: string, fn: Function): IWuJieEventBus;
$offAll(fn: Function): IWuJieEventBus;
$emit(event: string, ...args: Array<any>): IWuJieEventBus;
$clear(): IWuJieEventBus;
}
export interface IWuJieInterface {
props: any;
bus: IWuJieEventBus;
}
export interface StateInterface {
// Define your own store structure, using submodules if needed
// example: ExampleStateInterface;
// Declared as unknown to avoid linting issue. Best to strongly type as per the line above.
initialized: boolean;
advanced_debug: boolean;
factory_mode: boolean;
signal_source_tree: SignalSourceTreeItemEntity[];
polling_tree: PollingTreeItemEntity[];
mode_tree: ModeTreeItemEntity[];
plan_tree: PlanTreeItemEntity[];
wall_row: number;
wall_col: number;
device_screen_width: number;
device_screen_height: number;
device_screen_refresh_rate: number;
device_screen_connect_state: boolean;
windows: WindowOpenNotifyEntity[];
windows_sort: string[];
device_ip_address: string;
power_on_plan: string;
fan_temp: number;
selected_window: string;
current_left_tab: string;
selected_signal_source: string;
selected_polling: string;
current_running_plan: string;
connect_list: ConnectTableEntity[];
modes: ModeEntity[];
plans: PlanEntity[];
pollings: PollingEntity[];
signal_sources: SignalSourceEntity[];
landspace: boolean;
device_attribute: number;
power_state: boolean;
product_name: string;
custom_defines: CustomDefines;
fusion_configuration: object;
isLedPlayer: () => boolean;
isSpecialVideo: () => boolean;
$wujie: IWuJieInterface | null;
//
selected_projector: string;
EnableBlending: boolean;
}
// provide typings for `this.$store`
declare module "@vue/runtime-core" {
interface ComponentCustomProperties {
$store: VuexStore<StateInterface>;
}
}
class _TreeHelper {
public static findNode(node: any, key: string, value: string): any {
if (node && node.children && key && value != null && value != undefined) {
if (node[key] == value) {
return node;
}
for (let child of <any[]>node.children) {
if (child && child[key] == value) {
return child;
} else {
let _r = _TreeHelper.findNode(child, key, value);
if (_r) {
return _r;
}
}
}
}
}
public static findNodeParent(node: any, key: string, value: string): any {
if (node && node.children && key && value != null && value != undefined) {
for (let child of <any[]>node.children) {
if (child && child[key] == value) {
return node;
} else {
let _r = _TreeHelper.findNodeParent(child, key, value);
if (_r) {
return _r;
}
}
}
}
}
public static addTreeItem(
tree: any,
defaultItem: () => any,
createTreeItem: (
uuid: string,
parent: string,
name: string,
is_group: boolean
) => any,
playload?: any
) {
if (tree && playload) {
const parent = playload.parent ?? "";
const is_group = playload.is_group ?? false;
let item_data = playload.item_data ?? defaultItem();
let node = _TreeHelper.findNode(tree[0], "uuid", item_data.uuid);
if (node) {
return;
}
node = _TreeHelper.findNode(tree[0], "uuid", parent);
if (node) {
const node_item = createTreeItem(
item_data.uuid,
parent,
item_data.name,
is_group
);
node_item.item_data = item_data;
(<any[]>node.children).push(node_item);
}
}
}
public static setTreeItem(
tree: any,
defaultItem: () => any,
copy: (left: any, right: any) => void,
playload?: any
) {
if (tree && playload) {
let item_data = playload.item_data ?? defaultItem();
let node = _TreeHelper.findNode(tree[0], "uuid", item_data.uuid);
if (node) {
copy(node.item_data, item_data);
node.name = item_data.name;
}
}
}
public static deleteTreeItem(tree: any, playload?: any) {
if (tree && playload && playload.uuid) {
let parent = _TreeHelper.findNodeParent(tree[0], "uuid", playload.uuid);
if (parent) {
let node_index = (<any[]>parent.children).findIndex(
(item) => item && item.uuid == playload.uuid
);
if (node_index != -1) {
(<any[]>parent.children).splice(node_index, 1);
}
}
}
}
public static findGroupsByParent(parent: string, array: any[]) {
return array.filter((item) => {
return item && item.parent_uuid == parent;
});
}
public static findItemsByParent(parent: string, array: any[]) {
return array.filter((item) => {
return item && item.group_uuid == parent;
});
}
public static buildGroup(
parent: any,
createTreeItem: (
uuid?: string,
parent?: string,
name?: string,
is_group?: boolean,
item_data?: any,
children?: any[]
) => any,
group_array: any[],
item_array: any[]
) {
if (parent) {
for (let item of _TreeHelper.findGroupsByParent(
parent.uuid,
group_array
)) {
const node_item = createTreeItem(
item.uuid,
parent.uuid,
item.name,
true
);
node_item.item_data = item;
parent.children.push(node_item);
_TreeHelper.buildGroup(
node_item,
createTreeItem,
group_array,
item_array
);
}
for (let item of _TreeHelper.findItemsByParent(parent.uuid, item_array)) {
const node_item = createTreeItem(
item.uuid,
parent.uuid,
item.name,
false,
item
);
parent.children.push(node_item);
}
}
}
public static buildTree(
tree: any,
group_name: string,
items_name: string,
root_text: string,
createTreeItem: (
uuid?: string,
parent?: string,
name?: string,
is_group?: boolean,
item_data?: any,
children?: any[]
) => any,
playload?: any
) {
if (
tree &&
playload &&
playload.response &&
playload.options &&
playload.options.$t
) {
const $t = playload.options.$t;
const groups = playload.response[group_name] ?? [];
const items = playload.response[items_name] ?? [];
const root = createTreeItem("", "", $t.t(root_text ?? "root"), true, {
uuid: "",
name: "",
parent_uuid: "",
group_uuid: "",
});
tree.splice(0, tree.length);
tree.push(root);
_TreeHelper.buildGroup(root, createTreeItem, groups, items);
} else {
console.error(playload);
}
}
}
// provide typings for `useStore` helper
export const storeKey: InjectionKey<VuexStore<StateInterface>> =
Symbol("vuex-key");
import window_color_list from "./window_color_list.js";
import { EProductNames } from "src/entities/ProductNames";
export const NullSignalSource =
"FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF";
export default store(function (/* { ssrContext } */) {
const Store: VuexStore<StateInterface> = createStore<StateInterface>({
modules: {
// example
},
state: {
// state
initialized: false,
advanced_debug: false,
factory_mode: false,
signal_source_tree: [],
polling_tree: [],
mode_tree: [],
plan_tree: [],
wall_col: 1,
wall_row: 1,
device_screen_width: 0,
device_screen_height: 0,
device_screen_refresh_rate: 0,
device_screen_connect_state: true,
windows: [],
windows_sort: [],
device_ip_address: "localhost",
power_on_plan: "",
fan_temp: 0,
selected_window: "",
current_left_tab: "signal_source",
selected_signal_source: NullSignalSource,
selected_polling: NullSignalSource,
current_running_plan: "",
connect_list: [],
modes: [],
plans: [],
pollings: [],
signal_sources: [],
landspace: window.innerWidth > window.innerHeight,
device_attribute: 0,
power_state: false,
fusion_configuration: {},
product_name: EProductNames.LED_PLAYER,
custom_defines: new CustomDefines(),
selected_projector: "0/0",
EnableBlending: false,
isLedPlayer: () => {
return (
Store.state.product_name == EProductNames.LED_PLAYER ||
Store.state.product_name == EProductNames.OLD_LED_PLAYER
);
},
isSpecialVideo: () => {
return Store.state.product_name == EProductNames.SPECIAL_VIDEO;
},
$wujie: null,
},
mutations: {
setInitialized(state: StateInterface, playload?: any) {
state.initialized = true;
},
updateLandspace(state: StateInterface, playload?: any) {
if (typeof playload == "boolean") {
state.landspace = playload;
}
},
setPowerState(state: StateInterface, playload: boolean) {
state.power_state = playload;
},
setProductName(state: StateInterface, playload?: any) {
if (
playload == EProductNames.LED_PLAYER ||
playload == EProductNames.SPECIAL_VIDEO ||
playload == EProductNames.OLD_LED_PLAYER
) {
state.product_name = playload;
}
},
setDeviceAttribute(state: StateInterface, playload?: any) {
const num = parseInt(playload);
if (!isNaN(num) && num >= 0) {
state.device_attribute = num;
// parse custom attributes
state.custom_defines.is_custom_isv =
(state.device_attribute & EDeviceAttribute.CustomISV) != 0;
state.custom_defines.function_output_board =
(state.device_attribute & EDeviceAttribute.OutputBoard) != 0;
state.custom_defines.function_center_control =
(state.device_attribute & EDeviceAttribute.CenterControl) != 0;
state.custom_defines.function_mirroring_output =
(state.device_attribute & EDeviceAttribute.MirroringOutput) != 0;
}
},
setAvancedDebug(state: StateInterface, playload?: any) {
if (playload || playload == "true") {
console.log("debug", playload);
state.advanced_debug = playload;
}
state.advanced_debug = playload;
},
setFactoryMode(state: StateInterface, playload?: any) {
if (playload || playload == "true") {
console.log("factory", playload);
}
state.factory_mode = playload;
},
setArrayValue(state: StateInterface, playload?: any) {
if (Array.isArray(playload.value)) {
const arr: Array<any> = (<any>state)[playload.name];
if (arr) {
arr.splice(0, arr.length);
for (const item of playload.value) {
if (item) {
arr.push(item);
}
}
}
}
},
setWindowPropertys(state: StateInterface, playload?: any[]) {
if (playload && Array.isArray(playload)) {
for (let item of playload) {
const window = item.window;
const property_name = item.property_name;
const value = item.value;
try {
if (window && property_name) {
window[property_name] = value;
}
} catch (e) {
console.log(e);
}
}
}
},
setWindowProperty(state: StateInterface, playload?: any) {
const window = playload.window;
const property_name = playload.property_name;
const value = playload.value;
if (window && property_name) {
window[property_name] = value;
}
},
setWindowClientProperty(state: StateInterface, playload?: any) {
const window = playload.window;
const property_name = playload.property_name;
const value = playload.value;
if (window && property_name) {
window.client_propertys[property_name] = value;
}
},
setWindows(state: StateInterface, playload?: WindowOpenNotifyEntity[]) {
if (playload) {
state.windows = playload;
state.windows_sort = [];
for (const item of state.windows) {
state.windows_sort.push(item.uuid);
}
for (const window of state.windows) {
if (window) {
try {
window.client_color = window_color_list.splice(
Math.round(Math.random() * window_color_list.length),
1
)[0];
} catch {}
}
}
}
},
clearWindows(state: StateInterface, playload?: any) {
state.windows = [];
state.windows_sort = [];
},
pushWindow(state: StateInterface, playload?: WindowOpenNotifyEntity) {
if (playload) {
if (
state.windows.find((e) => e && e.window_id == playload.window_id)
) {
return;
}
try {
playload.client_color = window_color_list.splice(
Math.round(Math.random() * window_color_list.length - 1),
1
)[0];
} catch {}
state.windows.push(playload);
state.windows_sort.push(playload.uuid);
}
},
topWindow(state: StateInterface, playload?: number) {
const window = state.windows.find(
(element) => element && element.window_id == playload
);
if (window) {
if (window) {
const index = state.windows_sort.findIndex(
(element) => element && element == window.uuid
);
if (index >= 0) {
state.windows_sort.splice(index, 1);
state.windows_sort.push(window.uuid);
}
}
}
},
lowerWindow(state: StateInterface, playload?: number) {
const window = state.windows.find(
(element) => element && element.window_id == playload
);
if (window) {
const index = state.windows_sort.findIndex(
(element) => element && element == window.uuid
);
if (index >= 0) {
state.windows_sort.splice(index, 1);
state.windows_sort.unshift(window.uuid);
}
}
},
removeWindow(state: StateInterface, playload?: any) {
const window_id = playload.window_id;
if (window_id) {
let index = state.windows.findIndex(
(item) => item && item.window_id == window_id
);
if (index >= 0) {
const window = state.windows[index];
window_color_list.push(window.client_color);
state.windows.splice(index, 1);
let __index = state.windows_sort.findIndex(
(element) => element && element == window.uuid
);
if (__index >= 0) {
state.windows_sort.splice(__index, 1);
}
}
} else {
console.log("window_id???");
}
},
cleanWindows(state: StateInterface, playload?: any) {
state.windows.splice(0, state.windows.length);
},
editWindow(state: StateInterface, playload?: any) {
const uuid = playload.uuid;
const new_window = playload.new_window as WindowOpenNotifyEntity;
if (uuid && new_window) {
let index = state.windows.findIndex(
(item) => item && item.uuid == uuid
);
if (index >= 0) {
state.windows[index] = new_window;
}
}
},
setWallCol(state: StateInterface, playload?: any) {
const num = parseInt(playload);
if (!isNaN(num) && num > 0) {
state.wall_col = num;
}
},
setWallRow(state: StateInterface, playload?: any) {
const num = parseInt(playload);
if (!isNaN(num) && num > 0) {
state.wall_row = num;
}
},
setDeviceScreenWidth(state: StateInterface, playload?: any) {
const num = parseInt(playload);
if (!isNaN(num) && num > 0) {
state.device_screen_width = num;
}
},
setDeviceScreenHeight(state: StateInterface, playload?: any) {
const num = parseInt(playload);
if (!isNaN(num) && num > 0) {
state.device_screen_height = num;
}
},
setDeviceScreenRefreshRate(state: StateInterface, playload?: any) {
const num = parseInt(playload);
if (!isNaN(num) && num > 0) {
state.device_screen_refresh_rate = num;
}
},
setDeviceScreenConnectState(state: StateInterface, playload?: any) {
try {
state.device_screen_connect_state = JSON.parse(playload);
} catch {}
},
// signal source
setSignalSourceTree(
state: StateInterface,
playload?: SignalSourceTreeItemEntity[]
) {
if (playload) {
state.signal_source_tree = playload;
}
},
setSelectedProjector(state: StateInterface, playload?: any) {
state.selected_projector = playload;
},
setEnableBlending(state: StateInterface, playload?: any) {
state.EnableBlending = playload;
},
clearSignalSourceTree(state: StateInterface, playload?: any) {
state.signal_source_tree = [];
},
pushSignalSourceTreeItem(
state: StateInterface,
playload?: SignalSourceTreeItemEntity
) {
if (playload) {
state.signal_source_tree.push(playload);
}
},
addSignalSourceTreeItem(state: StateInterface, playload?: any) {
if (playload) {
const parent = playload.parent ?? "";
const is_group = playload.is_group ?? false;
let item_data = playload.item_data ?? new SignalSourceEntity();
if (item_data && item_data.local_file_flag) {
return;
}
let node = _TreeHelper.findNode(
state.signal_source_tree[0],
"uuid",
item_data.uuid
);
if (node) {
return;
}
node = _TreeHelper.findNode(
state.signal_source_tree[0],
"uuid",
parent
);
if (node) {
const node_item = new SignalSourceTreeItemEntity(
item_data.uuid,
parent,
item_data.name,
is_group
);
node_item.item_data = item_data;
(<any[]>node.children).push(node_item);
}
}
},
setSignalSourceTreeItem(state: StateInterface, playload?: any) {
if (playload) {
let item_data = playload.item_data ?? new SignalSourceEntity();
let node = _TreeHelper.findNode(
state.signal_source_tree[0],
"uuid",
item_data.uuid
);
if (node) {
SignalSourceEntity.copy(node.item_data, item_data);
node.name = item_data.name;
}
}
},
deleteSignalSourceTreeItem(state: StateInterface, playload?: any) {
if (playload && playload.uuid) {
let parent = _TreeHelper.findNodeParent(
state.signal_source_tree[0],
"uuid",
playload.uuid
);
if (parent) {
let node_index = (<any[]>parent.children).findIndex(
(item) => item && item.uuid == playload.uuid
);
if (node_index != -1) {
(<any[]>parent.children).splice(node_index, 1);
}
}
}
},
buildSignalSourceTree(state: StateInterface, playload?: any) {
const buildGroup = (
parent: SignalSourceTreeItemEntity,
group_array: any[],
item_array: any[]
) => {
if (parent) {
for (let item of findGroupsByParent(parent.uuid, group_array)) {
const node_item = new SignalSourceTreeItemEntity(
item.uuid,
parent.uuid,
item.name,
true
);
node_item.item_data = item;
parent.children.push(node_item);
buildGroup(node_item, group_array, item_array);
}
for (let item of findItemsByParent(parent.uuid, item_array)) {
const node_item = new SignalSourceTreeItemEntity(
item.uuid,
parent.uuid,
item.name,
false,
item
);
if (
node_item &&
node_item.item_data &&
!node_item.item_data.local_file_flag
) {
parent.children.push(node_item);
}
}
}
};
const findGroupsByParent = (parent: string, array: any[]) => {
return array.filter((item) => {
return item && item.parent_uuid == parent;
});
};
const findItemsByParent = (parent: string, array: any[]) => {
return array.filter((item) => {
return item && item.group_uuid == parent;
});
};
if (
playload &&
playload.response &&
playload.options &&
playload.options.$t
) {
const $t = playload.options.$t;
const signal_source_groups =
playload.response.signal_source_groups ?? [];
const signal_sources = playload.response.signal_sources ?? [];
const root = new SignalSourceTreeItemEntity(
"",
"",
$t.t("signal source"),
true,
new SignalSourceEntity()
);
state.signal_source_tree.splice(0, state.signal_source_tree.length);
state.signal_source_tree.push(root);
buildGroup(root, signal_source_groups, signal_sources);
} else {
console.error(playload);
}
},
//mode tree
setModeTree(state: StateInterface, playload?: ModeTreeItemEntity[]) {
if (playload) {
state.mode_tree = playload;
}
},
clearModeTree(state: StateInterface, playload?: any) {
state.mode_tree = [];
},
pushModeTreeItem(state: StateInterface, playload?: ModeTreeItemEntity) {
if (playload) {
state.mode_tree.push(playload);
}
},
addModeTreeItem(state: StateInterface, playload?: any) {
_TreeHelper.addTreeItem(
state.mode_tree,
() => new ModeEntity(),
(uuid: string, parent: string, name: string, is_group: boolean) =>
new ModeTreeItemEntity(uuid, parent, name, is_group),
playload
);
},
setModeTreeItem(state: StateInterface, playload?: any) {
_TreeHelper.setTreeItem(
state.mode_tree,
() => new ModeEntity(),
(left: any, right: any) => ModeEntity.copy(left, right),
playload
);
},
deleteModeTreeItem(state: StateInterface, playload?: any) {
_TreeHelper.deleteTreeItem(state.mode_tree, playload);
},
buildModeTree(state: StateInterface, playload?: any) {
_TreeHelper.buildTree(
state.mode_tree,
"mode_groups",
"modes",
"mode",
(
uuid?: string,
parent?: string,
name?: string,
is_group?: boolean,
item_data?: any,
children?: ModeTreeItemEntity[]
) =>
new ModeTreeItemEntity(
uuid,
parent,
name,
is_group,
item_data,
children
),
playload
);
},
// plan tree
setPlanTree(state: StateInterface, playload?: PlanTreeItemEntity[]) {
if (playload) {
state.plan_tree = playload;
}
},
clearPlanTree(state: StateInterface, playload?: any) {
state.plan_tree = [];
},
pushPlanTreeItem(state: StateInterface, playload?: PlanTreeItemEntity) {
if (playload) {
state.plan_tree.push(playload);
}
},
addPlanTreeItem(state: StateInterface, playload?: any) {
_TreeHelper.addTreeItem(
state.plan_tree,
() => new PlanEntity(),
(uuid: string, parent: string, name: string, is_group: boolean) =>
new PlanTreeItemEntity(uuid, parent, name, is_group),
playload
);
},
setPlanTreeItem(state: StateInterface, playload?: any) {
_TreeHelper.setTreeItem(
state.plan_tree,
() => new PlanEntity(),
(left: any, right: any) => PlanEntity.copy(left, right),
playload
);
},
deletePlanTreeItem(state: StateInterface, playload?: any) {
_TreeHelper.deleteTreeItem(state.plan_tree, playload);
},
buildPlanTree(state: StateInterface, playload?: any) {
_TreeHelper.buildTree(
state.plan_tree,
"plan_groups",
"plans",
"plan",
(
uuid?: string,
parent?: string,
name?: string,
is_group?: boolean,
item_data?: any,
children?: PlanTreeItemEntity[]
) =>
new PlanTreeItemEntity(
uuid,
parent,
name,
is_group,
item_data,
children
),
playload
);
},
// polling tree
setPollingTree(
state: StateInterface,
playload?: PollingTreeItemEntity[]
) {
if (playload) {
state.polling_tree = playload;
}
},
clearPollingTree(state: StateInterface, playload?: any) {
state.polling_tree = [];
},
pushPollingTreeItem(
state: StateInterface,
playload?: PollingTreeItemEntity
) {
if (playload) {
state.polling_tree.push(playload);
}
},
addPollingTreeItem(state: StateInterface, playload?: any) {
_TreeHelper.addTreeItem(
state.polling_tree,
() => new PollingEntity(),
(uuid: string, parent: string, name: string, is_group: boolean) =>
new PollingTreeItemEntity(uuid, parent, name, is_group),
playload
);
},
setPollingTreeItem(state: StateInterface, playload?: any) {
_TreeHelper.setTreeItem(
state.polling_tree,
() => new PollingEntity(),
(left: any, right: any) => PollingEntity.copy(left, right),
playload
);
},
deletePollingTreeItem(state: StateInterface, playload?: any) {
_TreeHelper.deleteTreeItem(state.polling_tree, playload);
},
buildPollingTree(state: StateInterface, playload?: any) {
_TreeHelper.buildTree(
state.polling_tree,
"polling_groups",
"pollings",
"signal polling",
(
uuid?: string,
parent?: string,
name?: string,
is_group?: boolean,
item_data?: any,
children?: PollingTreeItemEntity[]
) =>
new PollingTreeItemEntity(
uuid,
parent,
name,
is_group,
item_data,
children
),
playload
);
},
// polling tree end
setDeviceIpAddress(state: StateInterface, playload?: any) {
if (playload) state.device_ip_address = playload;
},
setPowerOnPlan(state: StateInterface, playload?: any) {
if (playload != null && playload != undefined)
state.power_on_plan = playload;
},
setFanTemp(state: StateInterface, playload?: any) {
const f = parseFloat(playload);
if (!isNaN(f)) {
state.fan_temp = f;
}
},
setSelectedWindow(state: StateInterface, playload?: any) {
state.selected_window = playload;
},
setCurrentLeftTab(state: StateInterface, playload?: any) {
if (typeof playload == "string") {
state.current_left_tab = playload;
}
},
setSelectedSignalSource(state: StateInterface, playload?: any) {
if (state.selected_signal_source == playload) {
// state.selected_signal_source = NullSignalSource;
} else {
state.selected_signal_source = playload;
}
},
setSelectedPolling(state: StateInterface, playload?: any) {
if (state.selected_polling == playload) {
state.selected_polling = NullSignalSource;
} else {
state.selected_polling = playload;
}
},
setCurrentRunningPlan(state: StateInterface, playload?: any) {
state.current_running_plan = playload;
},
setConnects(state: StateInterface, playload?: any) {
state.connect_list = playload;
},
addConnectItem(state: StateInterface, playload?: any) {
state.connect_list.push(playload);
},
cleanConnectItem(state: StateInterface, playload?: any) {
const index = state.connect_list.findIndex(
(element) => element && element.uuid == playload
);
if (index != -1) {
state.connect_list.slice(index, 1);
}
},
setWuJie(state: StateInterface, playload?: any) {
state.$wujie = playload;
},
},
getters: {
GetTheCurrentlySelectedCamera(state) {
let arr = state.selected_projector.split("/");
return [Number(arr[0]), Number(arr[1])];
},
},
// enable strict mode (adds overhead!)
// for dev mode and --debug builds only
strict: !!process.env.DEBUGGING,
});
return Store;
});
export function useStore() {
return vuexUseStore(storeKey);
}