Referential Navigation ====================== Forked from https://www.drupal.org/sandbox/dman/2209055; see discussion on https://www.drupal.org/node/1815276 Construct pathauto and breadcrumb rules for structures that are held together with entity reference links. For those that don't like 'menus' or 'books' and their hierarchical structure, this strategy assumes a site structure where one content type (Publication Series) may refer to another content type (Publication Issue) and that may refer to another (Publication Article). The URL patterns need to reflect the heirarchy, even though each layer is not a menu or anything. To achive this, a pathauto token of '[referers-path]' witll return the PATH OF THE ENTITY THAT LINKS TO THIS ONE (effectively the parent node). Chaining these together should produce a meaningful URL hierarchy. Additional side effects are triggered such that : * whenever a parent item is renamed, the paths of each of its children are rebuilt * whenever a parent item is published, each child item is published. Originally built for NIWA on Drupal6 with a lot of customizations, refactored in D7 to be less ad-hoc, and adapted for D8. Behavior -------- Incoming reference Token ------------------------ This makes a new token tree available called "incoming_references": [node:incoming_references:field_child_pages:0:*] Underneath 'incoming_references:' will be each fieldname for any entity reference that may refer *to* the current node context (i.e., the field on the parent referencing the current node). The next part of the token path is a numeric index, as there may be many incoming references and you may just want the first (sort order is undetermined). At that point you can access the token tree of the entity type that may be found by that lookup, eg 'title' for a referring node. Edit propogation ---------------- Editing a parent may be expected to produce effects on the children. Usage ----- Given a content type that links to 'child' pages via an entityreference field called 'child_pages', The pathauto rules for child pages may be set as [node:incoming_references:field_child_pages:0:url:path]/[node:title] to use the first parents path as a base. Notes ----- * This does not use or require entity_tokens.module, though it should not clash. * The database lookup fo rthe reverse relationship may need to be improved as it doesn't use the full field API. An alternative is adding views as a dependency and just getting views to run the lookup for us.