mirror of
https://gitlab.com/bmcgonag/get_my.git
synced 2026-03-26 15:58:50 +00:00
82 lines
3 KiB
JavaScript
82 lines
3 KiB
JavaScript
import { M } from '../lib/assets/materialize.js';
|
|
import { Products } from '../../imports/api/products.js';
|
|
import { MenuItems } from '../../imports/api/menuItems';
|
|
import { MenuProdLinks } from '../../imports/api/menuProdLinks.js';
|
|
|
|
Template.modalLinkProducts.onCreated(function() {
|
|
this.subscribe("myMenuItems");
|
|
this.subscribe("myProducts");
|
|
this.subscribe("menuProdLinkData");
|
|
});
|
|
|
|
Template.modalLinkProducts.onRendered(function() {
|
|
var elems = document.querySelectorAll('.modal');
|
|
var instances = M.Modal.init(elems, {});
|
|
|
|
var elemse = document.querySelectorAll('select');
|
|
var instancese = M.FormSelect.init(elemse, {
|
|
dropdownOptions: 4,
|
|
});
|
|
|
|
setTimeout(function() {
|
|
var instances = M.Modal.init(elems, {});
|
|
var instancese = M.FormSelect.init(elemse, {
|
|
dropdownOptions: 4,
|
|
});
|
|
}, 250);
|
|
});
|
|
|
|
Template.modalLinkProducts.helpers({
|
|
products: function() {
|
|
return Products.find({}, {sort: { prodName:1 }});
|
|
}
|
|
});
|
|
|
|
Template.modalLinkProducts.events({
|
|
'click #saveLink' (event) {
|
|
event.preventDefault();
|
|
let menuItemId = Session.get("menuItemId");
|
|
let menuItemName = Session.get("menuItemName");
|
|
let linkSelect = document.getElementById('prodForMenu');
|
|
let linkObjArray = [];
|
|
let links = M.FormSelect.getInstance(linkSelect).getSelectedValues();
|
|
if (typeof links != undefined && links != [] && links != null) {
|
|
// let's split these links into their parts, and make an array of objects
|
|
for (let i=0; i<links.length; i++) {
|
|
let linkArray = links[i].split('|');
|
|
let key = linkArray[0];
|
|
let value = linkArray[1];
|
|
let linkObj = { prodId: key, prodName: value };
|
|
linkObjArray.push(linkObj);
|
|
}
|
|
|
|
const addMenuProdLinks = async() => {
|
|
let result = await Meteor.callAsync("add.menuProdLinks", menuItemId, menuItemName, linkObjArray);
|
|
if (!result) {
|
|
console.log(" ERROR adding product links to this menu item: " + err);
|
|
} else {
|
|
updMenuItemLinks();
|
|
}
|
|
}
|
|
addMenuProdLinks();
|
|
|
|
const updMenuItemLinks = async() => {
|
|
let result = await Meteor.callAsync('update.menuItemLinked', menuItemId, true);
|
|
if (!result) {
|
|
console.log(" ERROR adding link to menu item: " + err);
|
|
} else {
|
|
linkInMenu();
|
|
}
|
|
}
|
|
|
|
const linkInMenu = async() => {
|
|
let result = await Meteor.callAsync('link.inMenu', menuItemId, true);
|
|
if (!result) {
|
|
console.log(" ERROR adding link to menu sub-item: " + error);
|
|
} else {
|
|
showSnackbar("Products added to Menu Item successfully!", "green");
|
|
}
|
|
}
|
|
}
|
|
}
|
|
});
|