1234567891011121314151617181920212223242526272829303132333435363738394041424344 |
- setup.uiGridCreate ??= () =>{
- $('#interface').addClass('grid-stack');
- const layoutFromStorage = JSON.parse(localStorage.getItem("GridStack") ?? "{}");
- $('.grid-stack .grid-stack-item:visible').toArray().forEach((element,index) => {
- for(const [key,val] of Object.entries(layoutFromStorage[index] ?? {})){
- element.setAttribute(key,val);
- }
- });
- setup.uiGrid = GridStack.init();
- let grid_stack = $('.grid-stack');
- grid_stack.on('change', function (event, items) {
- let r = {};
- $('.grid-stack .grid-stack-item:visible').toArray().forEach((element,index) => {
- r[index] ??= {};
- const attributes = element.attributes;
- for (let i = 0; i < attributes.length; i++) {
- const attr = attributes[i];
- if (attr.name.startsWith('gs')) {
- r[index][attr.name] = attr.value;
- }
- }
- });
- localStorage.setItem("GridStack", JSON.stringify(r));
- });
- }
- setup.uiGridDestroy = () => {
-
- if(!setup.uiGrid)
- return;
- setup.uiGrid.destroy(false);
- $('#interface').removeClass('grid-stack');
-
- }
|