콘텐츠로 건너뛰기
Odoo 메뉴
  • 로그인
  • 무료 체험하기
  • 앱
    재무 관리
    • 회계
    • 청구서 관리
    • 비용 관리
    • 스프레드시트 (BI)
    • 문서
    • 전자 서명
    판매
    • CRM
    • 판매
    • POS 스토어
    • POS 레스토랑
    • 구독
    • 렌탈
    웹사이트
    • 웹사이트 빌더
    • 이커머스
    • 블로그
    • 포럼
    • 실시간 채팅
    • 온라인 학습 관리
    공급망
    • 재고 관리
    • 제조 관리
    • 제품 수명주기 관리 (PLM)
    • 매입
    • 유지관리
    • 품질
    인적자원 관리
    • 직원
    • 채용
    • 휴가 관리
    • 인사 평가
    • 인재 추천
    • 차량 관리
    마케팅
    • 소셜 마케팅
    • 이메일 마케팅
    • SMS 마케팅
    • 행사
    • 마케팅 자동화
    • 설문 조사
    서비스
    • 프로젝트
    • 작업 기록
    • 현장 서비스
    • 헬프데스크
    • 일정 관리
    • 일정 예약
    생산성
    • 메일 및 채팅
    • 전자 결재
    • IoT
    • VoIP
    • 지식 센터
    • WhatsApp
    타사 앱 Odoo 스튜디오 Odoo 클라우드 플랫폼
  • 인더스트리
    리테일
    • 서점
    • 의류 매장
    • 가구점
    • 식료품점
    • 철물점
    • 장난감 가게
    식음료 & 숙박업
    • 바 & 펍
    • 레스토랑
    • 패스트푸드
    • 게스트 하우스
    • 음료 유통업체
    • 호텔
    부동산
    • 부동산 중개업체
    • 건축 회사
    • 건설
    • 부동산 관리
    • 가드닝
    • 부동산 소유자 협회
    컨설팅
    • 회계 법인
    • Odoo 파트너
    • 마케팅 대행사
    • 법률 사무소
    • 인재 영입
    • 감사 및 인증
    제조 관리
    • 텍스타일
    • 메탈
    • 가구
    • 푸드
    • 양조장
    • 기업용 선물
    건강 & 피트니스
    • 스포츠 클럽
    • 안경점
    • 피트니스 센터
    • 웰니스 전문가
    • 약국
    • 미용실
    사업
    • 핸디맨
    • IT 하드웨어 및 지원 서비스
    • 태양 에너지 시스템
    • 제화업체
    • 클리닝 서비스
    • HVAC 서비스
    기타
    • 비영리 단체
    • 환경 에이전시
    • 광고판 임대
    • 사진
    • 자전거 임대
    • 소프트웨어 리셀러
    전체 인더스트리 찾아보기
  • 커뮤니티
    학습
    • 튜토리얼
    • 문서
    • 인증
    • 훈련
    • 블로그
    • 팟캐스트
    교육 역량 강화
    • 교육 프로그램
    • Scale-Up! 경영관리 게임
    • Odoo에 방문해보세요
    소프트웨어 신청
    • 다운로드
    • 버전 살펴보기
    • 릴리즈 내역
    협업
    • Github
    • 포럼
    • 행사
    • 번역
    • 파트너 등록
    • 파트너 대상 서비스
    • 회계 법인 정보 등록
    서비스 신청
    • 파트너 검색
    • 회계사 검색
    • 전문 상담 예약
    • 구현 서비스
    • 고객 정보
    • 고객 지원
    • 업그레이드
    Github 유튜브 트위터 링크드인 인스타그램 페이스북 스포티파이
    +1 (650) 691-3277
    데모 예약하기
  • 요금제
  • 고객 지원

Odoo is the world's easiest all-in-one management software.
It includes hundreds of business apps:

  • CRM
  • e-Commerce
  • 회계
  • 재고 관리
  • PoS
  • 프로젝트
  • MRP
All apps
커뮤니티에 참여하려면 회원 가입을 하시기 바랍니다.
모든 게시물 사용자 배지
태그 (모두 보기)
odoo accounting v14 pos v15
게시판 정보
커뮤니티에 참여하려면 회원 가입을 하시기 바랍니다.
모든 게시물 사용자 배지
태그 (모두 보기)
odoo accounting v14 pos v15
게시판 정보
도움말

I need to get a selection or many2one field with projects where the contact is follower?

구독

이 게시물에 활동이 있으면 알림 받기

신고된 질문입니다
projectfollowerodoo10
3 답글
9981 화면
아바타
Samo Arko

I'm creating a custom module connected many2one to res_partner, that has some data for tasks that the contact has. I've tried first with a selection field and then with a many2one field, but nothing worked.

Can some one help, am I doing it wrong, is there a better way?

The try with selection field

def get_contacts_projects(self):
        selection_list = list()        
        if self.partner_id:
            following = self.env['mail.followers'].sudo().search([('partner_id', '=', self.partner_id.id),
                                                                  ('res_model', '=', 'project.project')])
            partners_sub_projects = list()
            for follow in following:
                partners_sub_projects.append(follow.res_id)

            projects = self.env['project.project'].sudo().search([('analytic_account_id.parent_project_id', '!=', False),
                                                                     ('id', '=', partners_sub_projects),
                                                                     ('active', '=', True)
                                                                     ])            
            for project in projects:
                selection_list.append((project.id, project.sudo().analytic_account_id.name))
        return selection_list

# the fields
partner_id = fields.Many2one('res.partner', string='Contact', required=True, ondelete='cascade') 
project_id = fields.Selection(selection=lambda self: self.get_contacts_projects())

The try with Many2one field

def get_contacts_projects(self):
        selection_list = list()        
        if self.partner_id:
            following = self.env['mail.followers'].sudo().search([('partner_id', '=', self.partner_id.id),
                                                                  ('res_model', '=', 'project.project')])
            for follow in following:
                selection_list.append(follow.res_id)
return selection_list

# the fields

partner_id = fields.Many2one('res.partner', string='Contact', required=True, ondelete='cascade')
project_id = fields.Many2one('project.project', string='Pod področje', domain=lambda self: [('id', 'in', self.get_contacts_projects())]) 


0
아바타
취소
Sehrish

Odoo Customization Tips: https://learnopenerp.tumblr.com/

Samo Arko
작성자

If you don't want to help you don't need to comment! I know how to use google and I didn't find a working answers on it! That's why I posted my problem on the forum!

아바타
faOtools
베스트 답변

Hi,

just a few notes regarding:

1. For making a selection method: it doesn't seem appropriate. The list of values becomes dynamic, what means that a really selected value might have been excluded from final selection lists. Such approach might be done even in case selection values might be enriched, not decreased. The simple example of a similar approach from the core:

def _return_model(self):
    self._cr.execute("SELECT model, name FROM ir_model ORDER BY name") 
  return self._cr.fetchall()

It is also important here, that in your method you do not have self.partner_id. When selection values are initiated, the field / model may be hardly achieved. So, selection is not an option for you without re-defining core methods.


2. For making a many2one field: it is seems much more appropriate. The point is that you selection values depend on an actually chosen field. Besides, you may also make many2one field shown as selection using the widget 'selection' in your xml view.

However, in your example you made it wrong: for dynamic domain you should apply onchange. I do not fully remember the syntax but it should be something like:

@api.multi
@api.onchange('partner_id')
def _onchange_partner_id(self):
    project_ids = [1, 2, 3] # find project by followers
    return {'domain': {'project_id': [('id', 'in', project_ids)]}}


UPDATE

According to the last comment: I guess the simplest way would be to make a wizard to select a project. So:

  1. Add the button 'Select a project' to a partner above the hours table

  2. As soon as he button is pressed our partner is saved and has real id (default button behaviour)

  3. The button click leads to an action with a new popup with 2 fields: (a) partner (current partner, invisible); (b) project_id → we apply on_change for a partner to make domain for selecting a project. It would be triggered since partner is applied by default as active_id

  4. A user selects a project among viable ones and press the button 'save' in the popup

  5. We write a selected project in a current partner 'project_id' field

  6. Hours are re-calculated


2
아바타
취소
Samo Arko
작성자

yeah... I know that the selection concept is wrong, but I tried it, because the filter domain didn't work. In filtering m2o field by domain it works like you made a example, with a fixed list, but NOT when you need first search the followers. The 'partner_id' doesn't change, because it expands the res_partner form view with a tree view.

faOtools

Hi, then make onchange for any other field, which has default. Default will trigger onchange and domain would be updated

Samo Arko
작성자

I'm trying to get it working, but I never used such a return. How is this used on the m2o field definition? I tried with no domain definition on the field but it doesn't work.

faOtools

There is no need to specify domain for a field. The onchange should work. Look for example at - https://www.odoo.com/forum/help-1/question/how-to-return-a-domain-on-field-on-onchange-action-13900. So, first of all, check that the onchange method is triggered (just some print or logger). Then, check that domain is constructed Okay (again some print like print ([('id', 'in', project_ids)])).

Samo Arko
작성자

Thanks for help, but it just won't work. Like I said if I return a fixed list like in your example it works your way or my way with lambda. The problem is that when you edit the line the partner_id relation is a <new Object> so it can't find it in the mail.followers table. I'll try using a wizard to bypass this <new Object> crap. Even if your way didn't work I'll up vote your answer for all the time you took for helping me

faOtools

Thank you for up-voting, although it is not my goal. By the way, if partner_id is a new object, it means that is not yet created (and would be created only when this object is saved). Thus, it means that you created partner_id in the field, don't you? But how then, a partner might be a follower in a project?

By the way, I just understood that my offer will anyway work only for the very first case, when partner is changed, but would be not updated afterwards, while it is needed (a partner might become a follower for new projects), isn't it?

We can't also use some sort of compute field, since it is impossible to search in non-stored fields, while there is no way to apply 'depends' on this partner followed projects (just there is no such stored field).

So, I'm afraid any of approaches here would lead to very limited results. In my opinion, there is a need to re-consider initial goal, otherwise the only way would be to make the special js widget for that which would be also low-performing.

Could you please elaborate what business purpose you trying to achieve? Not in terms of models and fields, but in terms of logical aim?

Samo Arko
작성자

The <new Object> for a ID is not only used when the record is not yet created, but it's the value of every relation when you edit the record. I tried creating the record with a button and set the partner_id.

My goal is to have on a contact(res.partner), usable hours for a project to be used in tasks timesheets where the contact is the customer of the task.

so on the contacts form view you have a tree view for the usable hours by project. The contact can have tasks on all projects he is a follower.

The whole module with the hours is working, only the project selection for the usable hours line on contact isn't working.

I really have no clue how to do this.

faOtools

I offers a simple way to achieve the same goal in the section 'update' of my initial answer. As for not having a wizard: I really guess the only way is to make a wizard, or use, for example, many2many_checkboxes widget with computed project_ids

Samo Arko
작성자

yeah... I figured as much that I'll need to use a wizard. I first tried with a button that creates the record with the partner_id and then I tried to fill the selection field with a method that gotten me the projects, but the method didn't work because of the same <new Object> problem.

토론이 재미있으신가요? 직접 참여해보세요!

지금 바로 가입하여 독점 서비스를 이용해보고 특별한 커뮤니티와 소통하세요!

가입
관련 게시물 답글 화면 활동
Unable to Install Project App.
project odoo10
아바타
0
2월 18
89
In project managment, where is the code that adds user to followers? 해결 완료
project follower mail task odoo10
아바타
아바타
1
7월 19
4035
Change "created date" value in Project
project date odoo10
아바타
아바타
2
8월 22
5875
Project Forecast in Odoo 10
project forecast odoo10
아바타
아바타
아바타
3
6월 18
5315
Merge Projects in Projects Module
project community odoo10
아바타
아바타
1
3월 18
4888
커뮤니티
  • 튜토리얼
  • 문서
  • 포럼
오픈 소스
  • 다운로드
  • Github
  • Runbot
  • 번역
서비스
  • Odoo.sh 호스팅
  • 고객 지원
  • 업그레이드
  • 맞춤 개발
  • 학습
  • 회계사 검색
  • 파트너 검색
  • 파트너 등록
회사 소개
  • 회사 소개
  • 브랜드 자산
  • 상담 문의
  • 인재 채용
  • 행사
  • 팟캐스트
  • 블로그
  • 고객 사례
  • 법적고지 • 개인정보
  • 보안
الْعَرَبيّة Català 简体中文 繁體中文 (台灣) Čeština Dansk Nederlands English Suomi Français Deutsch हिंदी Bahasa Indonesia Italiano 日本語 한국어 (KR) Lietuvių kalba Język polski Português (BR) română русский язык Slovenský jazyk slovenščina Español (América Latina) Español ภาษาไทย Türkçe українська Tiếng Việt

Odoo는 CRM, 이커머스, 회계, 재고, POS, 프로젝트 관리 등 기업의 모든 요구 사항을 충족하도록 설계된 오픈 소스 기반의 통합 비즈니스 앱 제품군입니다.

Odoo의 간편한 UI와 완벽하게 통합된 기능을 직접 확인해 보세요.

Website made with

Odoo Experience on YouTube

1. Use the live chat to ask your questions.
2. The operator answers within a few minutes.

Live support on Youtube
Watch now