"use strict";

const $ = require("jquery");
const socket = require("../socket");
const options = require("../options");

socket.on("sync_sort", function(data) {
	// Syncs the order of channels or networks when they are reordered
	if (options.ignoreSortSync) {
		options.ignoreSortSync = false;
		return; // Ignore syncing because we 'caused' it
	}

	const type = data.type;
	const order = data.order;
	const container = $(".networks");
	const network = container.find(`.network[data-uuid="${data.target}"]`);

	if (type === "networks") {
		$.each(order, function(index, value) {
			const position = $(container.children(".network")[index]);

			if (position.data("id") === value) { // Network in correct place
				return true; // No point in continuing
			}

			network.insertBefore(position);
		});
	} else if (type === "channels") {
		$.each(order, function(index, value) {
			if (index === 0) { // Shouldn't attempt to move lobby
				return true; // same as `continue` -> skip to next item
			}

			const position = $(network.children(".chan")[index]); // Target channel at position

			if (position.data("id") === value) { // Channel in correct place
				return true; // No point in continuing
			}

			const channel = network.find(".chan[data-id=" + value + "]"); // Channel at position

			channel.insertBefore(position);
		});
	}
});