Обновление №8 для версии VOGBIT 1.1.37841 - Новые «Терминалы», новый модуль для «Совместной обработки» в производстве, переработанный режим «Обеспеченность»

Последние темы на форумах VOGBIT

Описание порядка выполнения операций при изготовлении - Состав и технология
Константин Чилингаров: Здравствуйте, Существующие в текущей версии варианты: 1. Не запускать "тройники" (не создавать задания) до тех пор, пока не сделаны "корпуса" и "штуцеры" (ну если только последние, конечно, не были сделаны заранее ...
В расчет потребности не попадают детали из готового изделия - Состав и технология
Константин Чилингаров: Такой вариант по смыслу соответствует тому, что изготовленные в рамках данного заказа детали, хотя и используются для сборочной единицы в этом же заказе, сначала передаются на склад (отмечается в программе). А потом через какое-то время выдаются со с ...
Перемещение в учетную группу - Ошибки в работе
Константин Чилингаров: Точно. Воспроизвёл. Так и есть. Это недоработка. Будем чинить. Спасибо!
Редактирование параметра профиль и размеры - Состав и технология
Константин Чилингаров: Называть параметры можно как угодно. В том числе переименовывать. И свои создавать, любые. От названия параметра ничего не зависит.  Можете, например, в своей базе переименовать, если есть желание. Почему не вывести параметр материала "профи ...
Как правильно организовать начальный импорт данных на склад - Экспорт импорт данных
Константин Чилингаров: 18911 Станислав написал: А по срокам примерно? День - неделя (в зависимости от загрузки в этот момент). Скорее, день. Плагин сам есть готовый. Вместе с краткой инструкцией и примером его дадим. Если что не получается, то 1-2 коротких консульта ...
Работа с заданиями - Производство
Константин Чилингаров: Здравствуйте, На "среднем" уровне задания не выдаются на пост на конкретную смену (основное предназначение режима "Новые задания"). Соответственно, в режиме "Новые задания" с ними делать нечего. Они там выводятся для ...
График производства перестал показывать вторую очередь - Производство
Станислав: 13 Константин Чилингаров ,  Спасибо! Я вас во все в принципе понял. С Уважением!
Обеспеченность с закрытыми заявками покупателей - Производство
Константин Чилингаров: Здравствуйте, Видимо, речь о том, что когда включены "учётные группы", то в "Обеспеченность" показываются внизу "пустые" остатки по всем ранее существовавшим группам (закрытым). Попробовал, да есть такая штука. Согл ...
Удалить расходную накладную - Материалы, Комплектующие, Складской учёт
Константин Чилингаров: 18911 Станислав написал: Странно, но ЕИ по умолчанию через некоторое время опять появились те же самые, что и были раньше.Т.е удаление их из окна связанных с номенклатурой объектов не решает проблемы, попробовал кг заменить на м, все равно устанав ...
Работа с заданиями - редактирование строки по конкретной операции над деталью - Производство
Константин Чилингаров: Здравствуйте, 18911 Станислав написал: В технологии за конкретной операцией Пиление заготовки пост на котором исполняется операция конкретно не указан, и поэтому в связанных объектах указано две ленточные пилы. Некоторые общие вещи по поводу ...
Удвоение потребности - Производство
Станислав: 13 Константин Чилингаров ,  Фигасе - походу "мозгу юзера" капец. Спасибо за пояснения. С Уважением!
Переключение между базами данных - Обновление
Константин Чилингаров: Здравствуйте, Разные "файлы программы" в базах. На одной стоит обновление, на другой нет. 4146 Владимир Трусов написал: Как это починить? Поставить последнее обновление на обе базы.
Информация о количестве изделий на терминале - Интерфейс программы
Константин Чилингаров: Здравствуйте, 3520 Alex-220781 написал: А сейчас эта кнопка работает? По моему после последнего обновления перестала Вроде работает. Вчера проверял, работала (тип терминала 4). Но она вообще изначально задумывалась для того, чтобы можно было ...
Терминал. Распределение заданий на разные участки. - Терминалы
Константин Чилингаров: Про выдачу одного задания на разные посты, которые на разных участках. Я бы всё таки настоятельно не рекомендовал так делать. Это идеологически изначально не предусмотрено, и чревато. Например, к "участку" привязывается "тип терминал ...
Выдача ТМЦ со склада "без основания" - Материалы, Комплектующие, Складской учёт
Константин Чилингаров: 18931 Volkov1 написал: Можно ли осуществлять выдачу любых номенклатурных позиций со склада? Ответ на одно сообщение выше. Проблема не в выдаче. Всё выдаётся и проводится в программе: накладная создаётся (в виде электронного документа в програ ...
Ошибки после обновления декабрь 2019 - Терминалы
Константин Чилингаров: Здравствуйте, 3520 Alex-220781 написал: они не связаны с отключением электричества или аварийным завершением но вот это 3520 Alex-220781 написал: аботник нажимает кнопку "завершить", выскакивает ошибка - это и есть аварийное з ...
Вопросы по демо версии - Демо версия
Станислав: 13 Константин Чилингаров , Здравствуйте! Не хотел Вас обидеть своими глупыми вопросами, но причина в том числе и не совсем дружественном интерфейсе проги и довольно сложной структуре данных, предназначенной для построения СУБД. У обычного реально ...
Комментарии к операциям - Прочее
Константин Чилингаров: Здравствуйте, В этом окошке (график работ по сменам/ детальный график) в этой колонке отображается комментарий к операции, указанный в техпроцессе.
Новые возможности. Объединённые задания. Как пользоваться? - Производство
Константин Чилингаров: У вас в списке всего деталей, которые можно объединить в группу: 8 шт, 2 шт и 2 шт. Вы говорите, что в группе деталей: 8шт, 2шт и 2шт. Больше одной такой "группы" из такого количества деталей создать не получится.
Ошибка при выводе на печать предварительных заказов в демо версии производство - Производство
Константин Чилингаров: Здравствуйте, В окне, где выбирается бланк отчёта (какой нужно распечатать), нужно выбрать подходящий шаблон и нажать "Ок" (не на "принтер"). См. /support/622/#_v7680 здесь , рис.68.

Пример создания плагина

Разработка приложений и функций - Плагины - Технические вопросы
Страницы: Пред. 1 2
Пример создания плагина
 
вопрос исчерпан! все по цепочке коллекция компонентов-компоненты-параметры и quontity найден
 
да, правильно
 
оказалось в sql просто :D, а в c# как половчее сделать?
 
Непонятен вопрос.

Есть объект "деталь" (номенклатура).
У него есть объекты - коллекции компонентов. В общем случае их много. Кто из них "техпроцесс", определяется по типу связи коллекции.

В коллекции есть компоненты (операции, материалы и др.). Кто из компонентов есть кто, определяется по типу связи компонента.

Норма расхода материала - это "количество" у компонента "материал" в коллекции "техпроцесс".
Параметры материала (заготовки) - это параметры компонента "материал" в коллекции "техпроцесс".

Вот с этими объектами и оперируйте.

Мы в своих плагинах, поскольку техпроцессов у детали может быть много и материалов в каждом техпроцессе может быть много, дополнительно выделяем такую сущность, как "основной материал" детали. Технически для этого соответствующий компонент (материал) из коллекции (техпроцесс) дополнительно привязывается, как связанный объект, к номенклатуре детали.
 
От детали (из номенклатуры )берем ID,в коллекции компонентов по(id детали)=ovnerid,находим id-(тех проц.),в компонентах по ovnerid=(id тех проц.)находим nomenclatureid -(материал) ...и.т.д,так представляю...а как реализовать?
 
Cписок коллекций по номенклатуре:
Код
var collections = ExtensibleApplication.Application.General.ComponentCollections(nomenclatureId)

Список компонентов коллекции:
Код
var comps = ExtensibleApplication.Application.General.Components(collectionId)

Поиск по спискам:
Код
var searchResult = bizObjectList.QuickSearch(new[]{"Имя свойства"}, new object[]{значение})
 
Например, есть ID номенклатуры у которой одна коллекция. В этой коллекции нам надо найти компонент с типом связи материал и поменять ему количество.

Код
var collections = ExtensibleApplication.Application.General.ComponentCollections(nomenclatureId);
var collectionId = collections[0].Id.AsLongInt; 
var comps = ExtensibleApplication.Application.General.Components(collectionId);
var searchResult = comps.QuickSearch(new[]{"LinkTypeUID"}, new object[]{"LT_Material"});
var mat = searchResult[0];
try
{
mat["Quantity"].Value = 123;
mat.Save();
}
finally
{
mat.Cancel();
}
 
Спасибо,так и пытаюсь собирать...
 
Большое всем СПАСИБО кнопка получилась отличная (норма матер,и сварку и краску  считает!!! все как и задумал)
.....беспокоит один вопрос что после ID 999999 ?
 
Цитата
что после ID 999999
ID 1000000  :)
 
тогда поместится все...
 
Код
Добавляем параметр так: 
1. получаете параметры нужного объекта(номенклатуры, компонента, коллекции...) 
2. создаёте новый параметр 
3. изменяете необходимые значения 
4. сохраняете и т.д...

Подскажите,пожалуйста, как такой же фокус проделать с папкой в дереве номенклатуры...
-выбираем номенклатурную поз.(-> piugin)
-добавляет папку в текущую папку номенклатуры с наименованием номенклатурной поз...(хочу упростить создание дерева номенклатуры для изделий, (сбор ед 1, входящие сборки и детали помещаем в папку с названием сбор ед 1, и т.д, )
 
Берём папки:
Код
var folders = ExtApp.Application.General.Folders(categoryId);

Создаём новую:
Код
var newFolder = folders.AddNew();
try
{
 newFolder.Name.Value = "новая папка";
 newFolder.ParentID.Value = folderId;//родительская папка
 newFolder.Save();
}
finally
{
 newFolder.Cancel();
}

Помещаем номенклатуру в папку:
Код
var nmk = nomenclatureItem as ArrangedObject;
try
{
 nmk["FolderId"].AsLongInt = folder.ID.AsLongInt;
 nmk.Save();
}
finally
{
 nmk.Cancel()
}
 
Здравствуйте , ув. разработчики.

Интересует вопрос , как сделать кнопку , нажатие на которую открывало бы окно создания новой папки , после создавалась эта папка ( с название которое ввели ) и в ней же находилось две дочерних папки ( к примеру с названиями Узлы и Детали ) .

И скажите пожалуйста как устанавливаются эти .dll файлы ( кинул в директорию программы, но кнопка не появилась )
Снимок.PNG (15.04 КБ)
Снимок1.PNG (3.05 КБ)
Изменено: Максим Прохоров - 08.09.2014 10:22:43
ООО "Нефтезаводмонтаж" , г.Волгоград
 
Всё тоже самое: создаёте папку
Код
var newFolder = folders.AddNew();
newFolder.ParentID.Value = folderId;//родительская папка
Создаёте диалог
Код
var folderDialog = new NodeEditForm(ExtApp);
в диалог подсовываете создаваемую папку
Код
folderDialog.DataSource = newFolder;
Показываете диалог, и если нажат ОК - сохраняете:
Код
if (folderDialog.ShowDialog() == PlugInFormShowResult.Ok)
            {               
                newFolder.Save();
            }
            else newFolder.Cancel();
Дальше создаёте новые папки "Узлы" и "Детали" с ParentId равным id newFolder'a
Цитата
Максим Прохоров пишет:
И скажите пожалуйста как устанавливаются эти .dll файлы ( кинул в директорию программы, но кнопка не появилась )
достаточно кинуть файлы в директорию программы. Если не появилась, то возможно кнопка скрыта - поищите в настройках панели инструментов. Если и там нет - значит что-то сделали не так
 
Спасибо, Сергей
ООО "Нефтезаводмонтаж" , г.Волгоград
 
Если я правильно понял, то код создания двух папок будет следующим ... в комментарий почему то не получается добавить его. Парсер не пропускает ...
Изменено: Максим Прохоров - 14.09.2014 18:37:21
ООО "Нефтезаводмонтаж" , г.Волгоград
 
Цитата
Максим Прохоров пишет:
Если я правильно понял, то код создания двух папок будет следующим ...
Код
var newFolder = folders.AddNew();
newFolder.Name.Value = "Узлы";
newFolder.ParentID.Value = newFolderId;
newFolder.Name.Value = "Детали";
newFolder.ParentID.Value = newFolderId;
Нет. Поняли не правильно. В вашем коде создаётся одна папка(AddNew). Затем одной и той же папке два раза присваивается разное наименование и 2 раза указывается родитель в дереве. +отсутствует сохранение.
Посмотрите сообщение №43 в этой теме. Там практически готовая функция для создания папок по названию и родителю.
 
Сергей! Сделал плагин, который загружает номенклатуру в Вогбит из файла .csv. Загрузку проходит нормально, но при повторной загрузке вылетает ошибка, что такая номенклатура есть. Пытаюсь организовать поиск в справочнике ранее загруженной номенклатуры, но что-то делаю не так. Подскажите где ошибка:
           try
           {
               using (StreamReader sr = new StreamReader(@"D:\nmkFile.csv", Encoding.Default))
               {
                   string[] headers = sr.ReadLine().Split('\t');
                   var folderId = ((IPlugInForm)activeForm).FormParams["FolderId"].AsLongInt;
                   var nmks = ExtApp.Application.General.Nomenclature(folderId, CatalogOptions.None);
                   foreach (string header in headers)
                   {
                       string strk = "";
                       while (!sr.EndOfStream)
                       {
                           string[] rows = sr.ReadLine().Split('\t');

                          /////Здесь бы нужен поиск по QuickSearch и в случае успеха номенклатуру не грузить
                           var searchResult = nmks.QuickSearch(new[] { "Name" }, new object[] { "ObjectNomenclature" });
                           ((ObjectNomenclature)searchResult[0]).NomenclatureValue;
                          ////////////////////////////////////////////////////////////­///////////////

                           var nmk = nmks.AddNew();
                           for (int i = 0; i < headers.Length; i++)
                           {
                               if (i == 0 && strk != rows[i])
                               {
                                   strk = rows[i];
                                   //Здесь можно добавить заказ
                               }
                               if (i == 2)
                               {
                                   nmk.Notation.Value = rows[i];
                               }
                               if (i == 1)
                               {
                                   nmk.Name.Value = rows[i];
                               }
                           }
                           nmk.Save();
                       }
                   }
               }
           }
           finally
           {
               //activeForm.Cancel();
           }
 
1. Обозначение номенклатуры должно быть уникально в рамках всей базы. Наименования могут быть одинаковыми. Соответственно, в поиске надо проверять Notation. Либо по наименованию(в случае если обозначение отсутствует). Это зависит от того, как у вас номенклатурный справочник ведётся. Ещё может быть случай, что обозначение совпадает, а наименование - нет.
2. В приведённом коде поиск производится в конкретной папке. Не факт, что уже существующая номенклатура лежит в этой папке.

В общем случае поиск номенклатуры по обозначению может выглядеть так:
Код
var nmks = ExtApp.Application.General.Nomenclature(-1, CatalogOptions.None);//беру весь справочник номенклатуры
......
var nmkNotation = rows[2];//обозначение номенклатуры из файла
var searchResult = nmks.QuickSearch(new[] { "Notation" }, new object[] { nmkNotation });//для наименования соответственно "Name" и rows[1]
if(searchResult != null && searchResult.Any())
{
//есть такая номенклатура
}

Есть ещё вариант поиска объекта по обозначению. Надо только тип объекта указать.
Код
ExtApp.Application.General.GetObjectByNotation()

Ну и можно ещё обрабатывать исключение при сохранении номенклатуры
Код
catch (SqlServerException exception)
{
   if (exception.Code == ErrorCode.NoteNotUnique)
   {
      //обозначение не уникально
   }
}
 
Реализовал первый вариант поиска, но если во втором варианте можно делать поиск объекта по обозначению любого типа, то где здесь указать тип объекта?

ExtApp.Application.General.GetObjectByNotation()

Потребуется поиск папок, заказов на производство, параметров. Второй вариант подойдет для этих целей?

Посмотрел, также базовые объекты по F11, но поле типа объекта там пустое и не очень понятно где ставить тип объекта, как он выглядит. Да и кнопку настройки не вижу в меню, чтобы сконфигурировать интерфейс.
 
Цитата
Николай Спирин написал:
где здесь указать тип объекта?
Второй параметр:
Код
ExtApp.Application.General.GetObjectByNotation(nmkNotation, (long)SystemObjectTypes.Nomenclature);
Цитата
Николай Спирин написал:
Второй вариант подойдет для этих целей?
Смотря как ведёте справочники. Обозначения может и не быть. Параметры в справочнике искать - подойдёт, параметры объекта искать - не подойдёт. Первый способ более гибкий.

Цитата
Николай Спирин написал:
поле типа объекта там пустое
Встаньте на ID. Или FolderID. Или любое другое Свойство-Идентификатор. Покажет какого типа объект с таким идентификатором.

Цитата
Николай Спирин написал:
кнопку настройки не вижу в меню, чтобы сконфигурировать интерфейс
здесь
 
Сергей! В общем загрузка номенклатуры и поиск ее для проверки получился. Но грузить и искать номенклатуру нужно будет с учетом папок и вместе с заказами на производство. Кроме того к каждой номенклатуре должен быть прикреплен техпроцесс, который должен быть создан сам заранее и все материалы загружены заранее, а потом должен как-то сопоставлен с номенклатурой изделия. Для таких загрузок с иерархией был бы  удобен формат json. В литературе пишут, что должна быть подключена дополнительная библиотека. Подскажите какая лучше подойдет для Вогбита, или ели есть выложите пример загрузки-выгрузки данных в этом формате.
 
Цитата
Николай Спирин написал:
каждой номенклатуре должен быть прикреплен техпроцесс, который должен быть создан сам заранее и все материалы загружены заранее, а потом должен как-то сопоставлен с номенклатурой изделия. Для таких загрузок с иерархией был бы  удобен формат json.
Вставлю пять копеек...

Тут дело не в формате.
А в том, что номенклатурная позиция одна отдельно взятая и данные для производства - это как-бы небо и земля.
Номенклатура - тут всё элементарно. Запись одна в справочнике. Поискали, есть - хорошо, нет - добавили запись новую. Всё, конец.

А если взять, например, техпроцесс, то это совсем другого порядка песня.
Это коллекция, в ней компоненты, параметры со значениями, связанные объекты с определёнными типами связей, связанные объекты с тем, на основе чего созданы компоненты.
И это только одна деталь.
В заказе в вашем случае таких десятки.
+ есть узлы.
Есть спецификации "конструкторские" и "заказные".
Есть связи между "операциями".
И всё это вместе представляет собой данные, чтобы потом одной кнопкой в производстве получались нужные задания, в разных случаях они правильно обрабатывались, где нужно работы объединялись в одно задание, где не нужно, чтобы не объединялись, чтобы по мере выполнения одной группы заданий предлагалась для выдачи следующая группа и т.д.

В общем, такую конструкцию из данных правильно соорудить - это совсем не одну запись найти - добавить...
В самом VOGBIT есть плагины специальные, в них прописана логика на всевозможные случаи. Как когда что заполнять, что с чем связывать.
Благодаря этому для пользователя всё легко и просто. Мышкой перетащил строчку из одного окошка в другое, и всё само создалось, связалось, думать не нужно, как там что внутри устроено.
А "генератор" так и вообще при определённой настойке сам, автоматически, всё это создаёт, заполняет, находит что нужно и использует, что нужно создаёт...
Эта часть программы внутри совсем не тривиальная.

Так вот.
Если вы хотите зачем-то это всё дело (не только номенклатуру, но и спецификации, техпроцессы) из VOGBIT читать, то это, в общем, не сложно. Берите, считывайте, сохраняйте в файл. Какого хотите формата.
Если же вы хотите это снаружи в VOGBIT зачем-то создавать, то тут, мягко говоря, вам работы надолго хватит. Очень надолго...
И, главное, непонятно зачем.
Намного проще в самом VOGBIT создавать то, что ему нужно для работы (техпроцессы те же). Он прекрасно это умеет. Это намного легче будет, чем программно снаружи пытаться соорудить то же самое в базе. Быстрее и легче просто будет эти техпроцессы в самом VOGBIT и сделать. Даже вручную, думаю. Не говоря уже о том, если "генератором".
В общем смысл в вашем конкретном случае создавать ТП в VOGBIT программой снаружи мне просто не понятен.
Но так-то дело ваше... Хотите, есть время и желание - изучайте, создавайте. Ничего невозможного нет. Просто придётся изучать, как это всё устроено, писать кучу кода, тестировать это потом всё на пригодность.
Хотите? Занимайтесь))
Изучайте. Начать вот с этого можно...

А формат файла какой - json, xml, самодельный какой-нибудь - это 25-й вопрос в данном случае. Какая разница из какого формата данные читать (писать в него). Вопрос в том, что и как делать с тем, что считал из файла - вот где тут 99 процентов, собственно, кроется. А формат файла то без разницы какой, по большому счёту.
 
В .NET есть "свои" средства для работы с JSON. Из сторонних можно ньютонсофт посмотреть. Вогбиту без разницы. Создание\изменение объектов всё равно придётся ручками прописывать. Ну и как сказано выше, цель всего этого мероприятия не очень понятна.
 
Сергей, я не точно выразился, техпроцесс не должен создаваться сам, тем более в Вогбите есть генератор ТП. Достаточно найти номенклатуру изделия с которой связан свой техпроцесс, а если номенклатура не найдена, то добавить ее и потом к ней сгенерировать техпроцесс, или, если это возможно, идентифицировать уже существующий техпроцесс как коллекцию с компонентами и связать его с новой номенклатурой. В примере подробного описания техпроцесса видно, что изделие Кронштейн связан с ТП1. Возможно эту связь один раз можно установить программно или вручную или наконец сгенерировать для новой номенклатуры новый техпроцесс, а потом пользоваться этой связкой при загрузке Заказа на производстве со своим списком номенклатуры изделий.

[img][/img]
 
Сергей! Все таки, возможно загруженную или созданную новую номенклатурную позицию связать один раз вручную или программно с существующим техпроцессом или даже потом вручную сгенерировать к этой номенклатуре новый техпроцесс? А потом пользоваться этой связкой при последующих загрузках.
 
"Сгенерировать" техпроцесс к уже существующей номенклатуре нельзя. "Генератор" на основании "шаблона" создаёт новую номенклатуру и к ней сам заполняет всё, что нужно.

"Приделать" существующий техпроцесс от одной номенклатуры (ТП не может существовать "оторванный" вообще от номенклатуры, это коллекция, а у коллекции в любом случае есть owner (номенклатура)) к другой номенклатуре - технически возможно, но я бы настоятельно не рекомендовал этого делать. Помимо техпроцесса там ещё много чего есть. Спецификации, в частности, и параметры. Кроме того, есть всё таки разница между "родной" коллекцией компонентов и "связанной" (приделанной от другой номенклатуры), и я не поручусь на 100% процентов, что на "связанных" коллекциях всё и во всех местах будет потом правильно работать.
В общем, я бы так делать не стал.

И в первом, и во втором случае намного проще взять "нормальную" номенклатуру, правильно созданную "генератором", и просто её переименовать. Если Вам хочется, чтобы она по другому называлась как-то.
 
Остается одно. Созданную номенклатуру вместе с id выгрузить в 1С, там ее сопоставить с номенклатурой 1С и выгружать вместе с id в Вогбит. Но техпроцесс то можно, наверное, создать в Вогбит программно и присвоить ему номер из 1С, а потом заполнить его номенклатурой найденной по id?
Страницы: Пред. 1 2
Сейчас на форуме (гостей: 17)
Всего зарегистрированных пользователей: 3003
Приняло участие в обсуждении: 350
Всего тем: 804
Всего сообщений: 6066

Полезные ссылки:
подготовка производства Видео-презентация Себестоимость инструкция Начало работы Расчёт комплектации Складской учёт технологическая подготовка производственный учет ТПП складской учет управление данными электронный архив График производства управление качеством Планирование мелкосерийного производства Техническая Подготовка Производства управление производством управление ремонтами Производственный заказ загрузка оборудования планирование производства Трудоёмкость расчет себестоимости Генератор отчетов Сменное задание производство металлоконструкций Задания для производства пост руководство администраторов VOGBIT Тип нормирования разработчика отчетов vogbit Заказ на производство Нормирование состав изделия демоверсия технология Планирование производства Состав изделия Обзор обновления Расчёт цены Интерфейс производственный заказ ЧПУ G-код План производства в виде диаграммы Гантта фактический учет затрат Документация металлоконструкции Способ расчёта склад Предприятие Затраты на производство Указания по заполнению техпроцесса VOGBIT Отпуск со склада улучшения лимитно-заборная карта
×
Вход на сайт