Relationship value visibility depends on another selection of a relationship value?

Collapse
X
 
  • Time
  • Show
Clear All
new posts
  • Marcel
    Member
    • Jul 2025
    • 33

    #1

    Relationship value visibility depends on another selection of a relationship value?

    Hi all,

    I have 3 Entities:

    1. CContract (Many-to-One relation to CProductLine and CContractType)
    2. CProductLine (One-to-Many relation to CContractType)
    3. CContractType

    I am in the Layout of the CContract Entity and when I am selecting a CProductLine (e.g. Insurances) under CContractType every ContractType that is related to the selected ProductLine should be selectable in the dropdown list. Is that possible? So based on the selected ProductLine the values under ContractType are filtered/visible.

    Click image for larger version

Name:	image.png
Views:	143
Size:	30.6 KB
ID:	119985

    I read something about a select-handlers and created the following.

    /.../client/custom/src/handlers/select-related/contract-type-by-product-line.js

    PHP Code:
    define('custom:handlers/select-related/contract-type-by-product-line', ['handler'], function (Dep) {

        return 
    Dep.extend({

            
    filterData: function () {
                const 
    productLineId this.model.get('productLineId');

                if (!
    productLineId) {
                    return 
    null;
                }

                return [
                    {
                        
    type'equals',
                        
    field'productLineId',
                        
    valueproductLineId
                    
    }
                ];
            }

        });
    });
    ​ 
    But that does not seem to work.

    Thanks!
  • Marcel
    Member
    • Jul 2025
    • 33

    #2
    Hi,

    does anyone has an idea or direction for me?

    Thanks!

    Comment

    • shalmaxb
      Senior Member
      • Mar 2015
      • 1763

      #3
      I guess custom filter will do, look for that

      Comment

      • calvinmatteo
        Junior Member
        • Aug 2025
        • 1

        #4
        Yes, it is possible to filter the dropdown list of CContractType based on the selected CProductLine. This can typically be achieved using a combination of JavaScript (for client-side filtering) and possibly server-side logic (if your data is being loaded dynamically sprunki).

        Comment

        • Marcel
          Member
          • Jul 2025
          • 33

          #5
          And a custom filter would also do it? How am I creating it?

          Thanks!

          Comment

          • Marcel
            Member
            • Jul 2025
            • 33

            #6
            Can someone tell me or give me a hint how to create a custom filter, please?

            Comment

            • yuri
              EspoCRM product developer
              • Mar 2014
              • 9479

              #7
              Did you specify the handler in metadata? clientDefs > {EntityType} > relationshipPanels > {link} > selectHandler ?

              Hi, I have an entity Project. It has multiple links to an entity Project Document, one for Budget, for Proposal, for Report, etc. For each Project Document, the Project that it belongs to is set. Now in the Project, I want to be able to select e.g. the budget. I click the select Project document. It opens the (small) list
              If you find EspoCRM good, we would greatly appreciate if you could give the project a star on GitHub. We believe our work truly deserves more recognition. Thanks.

              Comment

              • yuri
                EspoCRM product developer
                • Mar 2014
                • 9479

                #8
                There's no such method 'filterData'. It might was obtained from a LLM response. There are multiple topics on the forum on this problem. No need to use LLMs with its random output.
                Last edited by yuri; 08-28-2025, 03:18 PM.
                If you find EspoCRM good, we would greatly appreciate if you could give the project a star on GitHub. We believe our work truly deserves more recognition. Thanks.

                Comment

                • Marcel
                  Member
                  • Jul 2025
                  • 33

                  #9
                  Hi Yuri,

                  thanks for your answer.

                  I added it into the clientDefs file

                  PHP Code:
                          "contractType": {
                              
                  "layout"null,
                              
                  "selectPrimaryFilterName"null,
                              
                  "selectHandler""custom:handlers/select-related/contract-type-by-product-line3"
                          
                  }, 
                  I have now a working filter but which is the correct one? Both are working. What are the differences?

                  PHP Code:
                  define('custom:handlers/select-related/contract-type-by-product-line3', ['handlers/select-related'], Dep => {

                      return class extends 
                  Dep {
                          
                  /**
                           * @param {module:model.Class} model
                           * @return {Promise<module:handlers/select-related~filters>}
                           */
                          
                  getFilters(model) {
                              
                  let advanced = {};

                              
                  let productLineId null;
                              
                  let productLineName null;

                              if (
                  model.get('productLineId')) {
                                  
                  productLineId model.get('productLineId');
                                  
                  productLineName model.get('productLineName');
                              }

                              if (
                  productLineId) {
                                  
                  // Option 1
                                  
                  advanced.productLine = {
                                      
                  attribute'productLineId',
                                      
                  type'equals',
                                      
                  valueproductLineId,
                                      
                  data: {
                                          
                  type'is',
                                          
                  nameValueproductLineName,
                                      },
                                  };

                                  
                  // Option 2
                                  // let nameHash = {};
                                  // nameHash[productLineId] = productLineName;

                                  // advanced.productLine = {
                                  //     field: 'productLine',
                                  //     type: 'linkedWith',
                                  //     value: [productLineId],
                                  //     data: {nameHash: nameHash},
                                  // };
                              
                  }

                              return 
                  Promise.resolve({
                                  
                  advancedadvanced,
                              });
                          }
                      }
                  }); 
                  Is it also possible to set a filter without the "Filtered by" in top of the selection? So the user can´t remove the filter and select/see anything else? Thanks!

                  Click image for larger version

Name:	image.png
Views:	39
Size:	22.9 KB
ID:	121004

                  Comment

                  • yuri
                    EspoCRM product developer
                    • Mar 2014
                    • 9479

                    #10
                    There's no such a feature.

                    You can the backend validation in the before-save API script, by throwing an error if not eligible product line is selected.
                    If you find EspoCRM good, we would greatly appreciate if you could give the project a star on GitHub. We believe our work truly deserves more recognition. Thanks.

                    Comment

                    • Marcel
                      Member
                      • Jul 2025
                      • 33

                      #11
                      Originally posted by yuri
                      There's no such a feature.

                      You can the backend validation in the before-save API script, by throwing an error if not eligible product line is selected.

                      Thank you!

                      Can you point me in the right direction how to do the check in the API Before Save Script?

                      Comment

                      Working...