223 lines
6.6 KiB
TypeScript
223 lines
6.6 KiB
TypeScript
import { store } from "quasar/wrappers";
|
|
import MultimediaWindowEntity from "src/entities/MultimediaWindowEntity";
|
|
import { SignalSourceTreeItemEntity } from "src/entities/SignalSourceEntity";
|
|
import { InjectionKey, reactive } from "vue";
|
|
import { useI18n } from "vue-i18n";
|
|
import {
|
|
createStore,
|
|
Store as VuexStore,
|
|
useStore as vuexUseStore,
|
|
} from "vuex";
|
|
|
|
// 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 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.
|
|
example: unknown;
|
|
signal_source_tree: SignalSourceTreeItemEntity[];
|
|
wall_row: number;
|
|
wall_col: number;
|
|
device_screen_width: number;
|
|
device_screen_height: number;
|
|
windows: MultimediaWindowEntity[];
|
|
}
|
|
|
|
// provide typings for `this.$store`
|
|
declare module "@vue/runtime-core" {
|
|
interface ComponentCustomProperties {
|
|
$store: VuexStore<StateInterface>;
|
|
}
|
|
}
|
|
|
|
// provide typings for `useStore` helper
|
|
export const storeKey: InjectionKey<VuexStore<StateInterface>> =
|
|
Symbol("vuex-key");
|
|
|
|
export default store(function (/* { ssrContext } */) {
|
|
const Store = createStore<StateInterface>({
|
|
modules: {
|
|
// example
|
|
},
|
|
state: {
|
|
// state
|
|
example: "",
|
|
signal_source_tree: [],
|
|
wall_col: 1,
|
|
wall_row: 1,
|
|
device_screen_width: 1920,
|
|
device_screen_height: 1080,
|
|
windows: [],
|
|
},
|
|
|
|
mutations: {
|
|
clearWindows(state: StateInterface, playload?: any) {
|
|
state.windows = [];
|
|
},
|
|
pushWindow(state: StateInterface, playload?: any) {
|
|
const window = playload as MultimediaWindowEntity;
|
|
if (window) {
|
|
state.windows.push(window);
|
|
}
|
|
},
|
|
removeWindow(state: StateInterface, playload?: any) {
|
|
const uuid = playload.uuid;
|
|
if (uuid) {
|
|
let index = state.windows.findIndex(
|
|
(item) => item && item.uuid == uuid
|
|
);
|
|
if (index >= 0) {
|
|
state.windows.splice(index, 1);
|
|
}
|
|
} else {
|
|
console.log("uuid???");
|
|
}
|
|
},
|
|
editWindow(state: StateInterface, playload?: any) {
|
|
const uuid = playload.uuid;
|
|
const new_window = playload.new_window as MultimediaWindowEntity;
|
|
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 (num != NaN && num > 0) {
|
|
state.wall_col = num;
|
|
}
|
|
},
|
|
setWallRow(state: StateInterface, playload?: any) {
|
|
const num = parseInt(playload);
|
|
if (num != NaN && num > 0) {
|
|
state.wall_row = num;
|
|
}
|
|
},
|
|
setDeviceScreenWidth(state: StateInterface, playload?: any) {
|
|
const num = parseInt(playload);
|
|
if (num != NaN && num > 0) {
|
|
state.device_screen_width = num;
|
|
}
|
|
},
|
|
setDeviceScreenHeight(state: StateInterface, playload?: any) {
|
|
const num = parseInt(playload);
|
|
if (num != NaN && num > 0) {
|
|
state.device_screen_height = num;
|
|
}
|
|
},
|
|
setSignalSourceTree(state: StateInterface, playload?: any) {
|
|
const item = playload as SignalSourceTreeItemEntity[];
|
|
if (item) {
|
|
state.signal_source_tree = item;
|
|
}
|
|
},
|
|
clearSignalSourceTree(state: StateInterface, playload?: any) {
|
|
// if (state.signal_source_tree) {
|
|
// state.signal_source_tree.splice(0, state.signal_source_tree.length);
|
|
// }
|
|
state.signal_source_tree = [];
|
|
},
|
|
pushSignalSourceTreeItem(state: StateInterface, playload?: any) {
|
|
let item = playload as SignalSourceTreeItemEntity;
|
|
if (item) {
|
|
state.signal_source_tree.push(item);
|
|
}
|
|
},
|
|
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
|
|
);
|
|
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
|
|
);
|
|
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("root"),
|
|
true
|
|
);
|
|
|
|
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);
|
|
}
|
|
},
|
|
},
|
|
|
|
// enable strict mode (adds overhead!)
|
|
// for dev mode and --debug builds only
|
|
strict: !!process.env.DEBUGGING,
|
|
});
|
|
|
|
return Store;
|
|
});
|
|
|
|
export function useStore() {
|
|
return vuexUseStore(storeKey);
|
|
}
|