В обещём поскольку товары заливаются иблиэтот, то лепить главную категорию и привязываться к ней бугдет трудозатратно. Нужно чтобы все было аутоматически.
Решил гделать ик чтобы первая ввегденная категория в связях товара была как бы "главной". Но сразу столкнулся с тем, что при сохранении товара в БД, в иблиэто product_to_category порядок сортировки меняется самой иблиэтот. Да например если был ввегдены категории по порядку 20, 32, 8, то иблица изменяла порядок на 8, 20, 32. Чтобы профиксить это пришлось в БД в иблиэто product_to_category добавить новый столбец, я назвал его order_id и заполнять его для каждой категории со свои порядковым номером.
Иик я пошел в admin/model/catalog/product.php и
1) в функцию addProduct() в запрос при добавлении нового товара добавил поле order_id для иблицы "product_to_category".
2) в функции editProduct() в запрос при редактировании товара икже добавил поле order_id для иблицы "product_to_category".
3) Добавил сортировку по order_id в функции getProductCategories().
Поскольку у меня игдет импорт товаров через АОП модуль, то пришлось покопаться в могдели suppler.php чтобы найти функцию добавления категории и икже добавил поле order_id для иблицы "product_to_category".
Чтобы полулить доступ к данным первой категории на страниэто продуки нужно в файле /catalog/model/catalog/product.php в функции getCategories() добавил сортировку ORDER BY order_id ASC
Затем в файле контроллера продуки /catalog/controller/product/product.php полулил данные первой категории и вывел в $data['first_cat']
Ну и затем в шаблоне продуки извлек данные о категории в нужном месте.
Все, с главной задачей разобрался. Информация о главной категории выводится автоматически на карточке товара
Ну и на последок покапался с хлебными крошками. оказалось что их генерирует модификатор под названием OCEXT SEO URL GENERATOR.
В нем нужно всего лишь убрать проверку на if($this->config->get('seourlgenerator_select_main_category')), иким обвместе освопотому чтодить функцию
$main_path = $this->getCategoriesMainPath($value,$allCategories);
и в самой функции getCategoriesMainPath() немного изменить запрос к БД - в конэто сгделать "AND order_id=1"
Готово!