| | |
| | | |
| | | //newBoxDetail.boxdtl_text1 = |
| | | |
| | | Dt_boxing_headRepository.Instance.Add(newBoxHead, true); |
| | | Dt_boxing_detailRepository.Instance.Add(newBoxDetail, true); |
| | | |
| | | //è·åç©ºè´§ä½ |
| | | Dt_locationinfo emptyLocation = CommonFunction.GetEmptyLocationAction(1); |
| | | Dt_locationinfo emptyLocation; |
| | | |
| | | int maxRetries = 20; |
| | | int retryCount = 0; |
| | | bool needRetry; |
| | | do |
| | | { |
| | | needRetry = false; // é»è®¤ä¸éè¦éè¯ |
| | | retryCount++; |
| | | |
| | | //è·åç©ºè´§ä½ |
| | | emptyLocation = CommonFunction.GetEmptyLocationAction(1); |
| | | if (emptyLocation == null) |
| | | { |
| | | return content.Error("æ æ³è·ååºä½"); |
| | | } |
| | | |
| | | // 2. æ£æ¥åºå |
| | | if (IsEmptyPalletLocation(emptyLocation.location_id)) |
| | | { |
| | | needRetry = true; |
| | | continue; // ç´æ¥è¿å
¥ä¸ä¸æ¬¡å¾ªç¯ï¼éè¯ï¼ |
| | | } |
| | | |
| | | // 3. æ£æ¥ä»»å¡ |
| | | if (Dt_taskinfoRepository.Instance.Find(x => x.task_endstation == emptyLocation.location_id).FirstOrDefault() != null) |
| | | { |
| | | needRetry = true; |
| | | continue; |
| | | } |
| | | |
| | | } while (needRetry && retryCount < maxRetries); |
| | | // æ£æ¥æ¯å¦è¶
è¿æå¤§éè¯æ¬¡æ° |
| | | if (retryCount >= maxRetries) |
| | | { |
| | | return content.Error($"æ æ³æ¾å°å¯ç¨åºä½ï¼å·²å°è¯ {retryCount} 次ï¼"); |
| | | } |
| | | LogRecord.WriteLog((int)LogEnum.InBound, $"æçæ¡ç ï¼{rfid},åé
çè´§ä½å·{emptyLocation.location_id}ï¼è´§ä½ç¶æï¼{emptyLocation.location_state}"); |
| | | |
| | | |
| | | Dt_boxing_headRepository.Instance.Add(newBoxHead, true); |
| | | Dt_boxing_detailRepository.Instance.Add(newBoxDetail, true); |
| | | |
| | | //è·åä»»å¡ |
| | | Dt_taskinfo tmpTaskInfo = CommonFunction.AddWMSTask_BoxPalletIn(emptyLocation, |
| | |
| | | } |
| | | Logger.AddLog(LoggerType.Add, saveModel, content, content); |
| | | return content; |
| | | } |
| | | |
| | | /// <summary> |
| | | /// æ£æ¥æå®è´§ä½æ¯å¦ä¸ºç©ºæçè´§ä½ |
| | | /// </summary> |
| | | /// <param name="locationId">è´§ä½ID</param> |
| | | /// <returns>true: æ¯ç©ºæçè´§ä½, false: 䏿¯ç©ºæçè´§ä½</returns> |
| | | public bool IsEmptyPalletLocation(string locationId) |
| | | { |
| | | try |
| | | { |
| | | // æ¥è¯¢ç©ºæçè´§ä½ä¿¡æ¯ |
| | | var emptyPalletLocation = VV_ContainerInfo_EmptyPalletRepository.Instance |
| | | .Find(x => x.location_id == locationId).FirstOrDefault(); |
| | | |
| | | // æ¥è¯¢è´§ä½ä¸ç容å¨ä¿¡æ¯ |
| | | var containerInfo = VV_ContainerInfoRepository.Instance |
| | | .Find(x => x.location_id == locationId).FirstOrDefault(); |
| | | |
| | | bool isEmptyPallet = emptyPalletLocation != null || containerInfo != null; |
| | | |
| | | return isEmptyPallet; |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | | LogRecord.WriteLog((int)LogEnum.Errer, $"æ£æ¥ç©ºæçè´§ä½å¤±è´¥ï¼è´§ä½IDï¼{locationId}ï¼é误ï¼{ex.Message}"); |
| | | return false; |
| | | } |
| | | } |
| | | |
| | | |
| | |
| | | VV_ContainerInfo_EmptyPallet emptyCon = VV_ContainerInfo_EmptyPalletRepository.Instance.FindFirst(x => x.containerhead_barcode == barcode); |
| | | if (emptyCon != null) |
| | | throw new Exception($"åºåä¸å卿çå·ï¼ã{barcode}ãçã空æãåºåï¼è¯·äººå·¥æ ¸å®ï¼æå¨è´§ä½ï¼{emptyCon.location_id}"); |
| | | //è·åç©ºè´§ä½ |
| | | Dt_locationinfo emptyLocation; |
| | | |
| | | //è¯´ææ¯ç©ºæå
¥åº |
| | | Dt_locationinfo emptyLocation = CommonFunction.GetEmptyLocationAction(1); |
| | | int maxRetries = 20; |
| | | int retryCount = 0; |
| | | bool needRetry; |
| | | do |
| | | { |
| | | needRetry = false; // é»è®¤ä¸éè¦éè¯ |
| | | retryCount++; |
| | | |
| | | //è·åç©ºè´§ä½ |
| | | emptyLocation = CommonFunction.GetEmptyLocationAction(1); |
| | | if (emptyLocation == null) |
| | | { |
| | | return content.Error("æ æ³è·ååºä½"); |
| | | } |
| | | |
| | | // 2. æ£æ¥åºå |
| | | if (IsEmptyPalletLocation(emptyLocation.location_id)) |
| | | { |
| | | needRetry = true; |
| | | continue; // ç´æ¥è¿å
¥ä¸ä¸æ¬¡å¾ªç¯ï¼éè¯ï¼ |
| | | } |
| | | |
| | | // 3. æ£æ¥ä»»å¡ |
| | | if (Dt_taskinfoRepository.Instance.Find(x => x.task_endstation == emptyLocation.location_id).FirstOrDefault() != null) |
| | | { |
| | | needRetry = true; |
| | | continue; |
| | | } |
| | | |
| | | } while (needRetry && retryCount < maxRetries); |
| | | // æ£æ¥æ¯å¦è¶
è¿æå¤§éè¯æ¬¡æ° |
| | | if (retryCount >= maxRetries) |
| | | { |
| | | return content.Error($"æ æ³æ¾å°å¯ç¨åºä½ï¼å·²å°è¯ {retryCount} 次ï¼"); |
| | | } |
| | | |
| | | LogRecord.WriteLog((int)LogEnum.InBound, $"æçæ¡ç ï¼{barcode},åé
çè´§ä½å·{emptyLocation.location_id}ï¼è´§ä½ç¶æï¼{emptyLocation.location_state}"); |
| | | |
| | | |