From e31dc0d4fc4a94208f43254be32a4902d74b1126 Mon Sep 17 00:00:00 2001 From: bachy Date: Fri, 18 May 2012 22:43:44 +0200 Subject: [PATCH 1/4] first RC Signed-off-by: bachy --- idmaterio.info | 29 ++++++++++++++++++++++ idmaterio.module | 64 ++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 93 insertions(+) create mode 100644 idmaterio.info create mode 100644 idmaterio.module diff --git a/idmaterio.info b/idmaterio.info new file mode 100644 index 00000000..f1a2418b --- /dev/null +++ b/idmaterio.info @@ -0,0 +1,29 @@ +name = Idmaterio +description = "The description of this module" + +; Core version (required) +core = 7.x + +; Package name (see http://drupal.org/node/542202 for a list of names) +; package = + +; PHP version requirement (optional) +; php = 5.2 + +; Loadable code files +; files[] = idmaterio.module +; files[] = idmaterio.admin.inc +; files[] = idmaterio.class.inc + +; Module dependencies +; dependencies[] = mymodule +; dependencies[] = theirmodule (1.2) +; dependencies[] = anothermodule (>=2.4) +; dependencies[] = views (3.x) + +; Configuration page +; configure = admin/config/idmaterio + + +; For further information about configuration options, see +; - http://drupal.org/node/542202 diff --git a/idmaterio.module b/idmaterio.module new file mode 100644 index 00000000..c8887c5c --- /dev/null +++ b/idmaterio.module @@ -0,0 +1,64 @@ +entityCondition('entity_type', $entity_type) + ->entityCondition('bundle', $entity->type) + ->fieldCondition('field_famille', 'value', $entity->field_famille['und'][0]['value']); + $result = $query->execute(); + if(is_array($result[$entity_type])){ + $entities = entity_load($entity_type, array_keys($result[$entity_type])); + + // get identifiants fo these entities + $ids = array(); + foreach ($entities as $id => $e) { + $identifiant = field_view_field($entity_type, $e, 'field_identifiant'); + $ids[] = $identifiant[0]['#markup'] ? intval($identifiant[0]['#markup']) : 0; + } + sort($ids); + + $value = strval(array_pop($ids) + 1); + }else{ + $value = '1'; + } + + // parse the value to a string as 0023 or 4458 or 0001 + $value_parts = str_split($value); + while (count($value_parts) < 4) { + array_unshift($value_parts, "0"); + } + + // record the result + $entity_field[0]['value'] = implode('', $value_parts); + } +} + +function computed_field_field_identifiant_display($field, $entity_field_item, $entity_lang, $langcode) { + return $entity_field_item['value']; +} \ No newline at end of file From b920153c138da617afc73418c03cbf77b2935c0e Mon Sep 17 00:00:00 2001 From: bachy Date: Mon, 21 May 2012 17:50:56 +0200 Subject: [PATCH 2/4] V1 RC Signed-off-by: bachy --- idmaterio.module | 56 +++++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 55 insertions(+), 1 deletion(-) diff --git a/idmaterio.module b/idmaterio.module index c8887c5c..5cb4a9b7 100644 --- a/idmaterio.module +++ b/idmaterio.module @@ -61,4 +61,58 @@ function computed_field_field_identifiant_compute(&$entity_field, $entity_type, function computed_field_field_identifiant_display($field, $entity_field_item, $entity_lang, $langcode) { return $entity_field_item['value']; -} \ No newline at end of file +} + + +/** + * Implements hook_form_alter(). + */ +function idmaterio_form_alter(&$form, &$form_state, $form_id) { + if($form_id == "materiau_node_form"){ + // $node = $form_state['node']; + // dsm($form, '$form'); + // dsm($form_state, '$form_state'); + // // + // $form['field_id_materio']['#markup'] = $node->field_famille['und']['default_value'] .'-'. $node->field_identifiant['und'][0]['value']; + + + } + + + +} +function idmaterio_nodeformcols_pre_form_alter(&$form){ + // dsm($form, 'node pre form col alter $form'); + + // $form['field_identifiant']['#prefix'] = '
'; + // $form['field_identifiant'] ['#markup'] = '

Hello !

'; + // $form['field_identifiant']['#suffix'] = '
'; + + // $form['materio_id'] = array( + // '#type'=>'markup', + // '#prefix' => '
', + // '#markup' => '

Hello !

', + // '#suffix' => '
', + // '#weight' => $form['field_identifiant']['#weight'], + // ); + + +} + +function idmaterio_nodeformcols_post_form_alter(&$form){ + // dsm($form, 'node post form col alter $form'); + + // $form['materio_id'] = array( + // '#type'=>'markup', + // '#prefix' => '
', + // '#markup' => '

Hello !

', + // '#suffix' => '
', + // '#weight' => $form['field_identifiant']['#weight'], + // ); + // + +} + + + + From 86d0eb03f5d40cb32e4ff47bb19b95e2a39c4e5e Mon Sep 17 00:00:00 2001 From: bachy Date: Fri, 5 Oct 2012 14:18:07 +0200 Subject: [PATCH 3/4] don't know Signed-off-by: bachy --- idmaterio.module | 83 +++++++++++++++++++++++++----------------------- 1 file changed, 43 insertions(+), 40 deletions(-) diff --git a/idmaterio.module b/idmaterio.module index 5cb4a9b7..4295e7b5 100644 --- a/idmaterio.module +++ b/idmaterio.module @@ -63,56 +63,59 @@ function computed_field_field_identifiant_display($field, $entity_field_item, $e return $entity_field_item['value']; } +function computed_field_field_reference_materio_compute(&$entity_field, $entity_type, $entity, $field, $instance, $langcode, $items) { + // dsm('-- computed --'); + // dsm($entity_field, '$entity_field'); + // dsm($entity_type, '$entity_type'); + // dsm($entity, '$entity'); + // dsm($field, '$field'); + // dsm($instance, '$instance'); + // dsm($items, '$items'); + if (!empty($entity_field[0]['value'])) { // the node is not new + return $entity_field[0]['value']; + } + else { // the node is new + $entity_field[0]['value'] = $entity->field_famille['und'][0]['value'].'-'.$entity->field_identifiant['und'][0]['value']; + } + +} + +function computed_field_field_reference_materio_display($field, $entity_field_item, $entity_lang, $langcode) { + return $entity_field_item['value']; +} /** * Implements hook_form_alter(). */ function idmaterio_form_alter(&$form, &$form_state, $form_id) { if($form_id == "materiau_node_form"){ - // $node = $form_state['node']; // dsm($form, '$form'); // dsm($form_state, '$form_state'); - // // - // $form['field_id_materio']['#markup'] = $node->field_famille['und']['default_value'] .'-'. $node->field_identifiant['und'][0]['value']; + $ref = $form['field_reference_materio']['und'][0]['value']['#default_value']; + if($ref != ''){ + $title = t('Edit').' '.$form['title']['#default_value'].' ('.$form['type']['#value'].' '.$ref.')'; + // dsm($title, '$title'); + + drupal_set_title($title); + + $form['reference'] = array( + '#markup' => t('Materio Reference').' : '.$ref.'', + '#prefix' => '
', + '#suffix' => '
', + ); + $form['reference']['#placement'] = array( + 'region' => 'right', + 'weight' => 0, + 'has_required' => FALSE, + 'hidden' => FALSE, + ); + // dsm(synonyms_get_synonyms(4346), 'synonyms_get_synonyms'); + // dsm(synonyms_get_synonym_root('fenouille'), 'synonyms_get_synonym_root'); + //dsm(synonyms_node_update_index($form['#node'])); + + } } - - - -} -function idmaterio_nodeformcols_pre_form_alter(&$form){ - // dsm($form, 'node pre form col alter $form'); - - // $form['field_identifiant']['#prefix'] = '
'; - // $form['field_identifiant'] ['#markup'] = '

Hello !

'; - // $form['field_identifiant']['#suffix'] = '
'; - - // $form['materio_id'] = array( - // '#type'=>'markup', - // '#prefix' => '
', - // '#markup' => '

Hello !

', - // '#suffix' => '
', - // '#weight' => $form['field_identifiant']['#weight'], - // ); - - } -function idmaterio_nodeformcols_post_form_alter(&$form){ - // dsm($form, 'node post form col alter $form'); - - // $form['materio_id'] = array( - // '#type'=>'markup', - // '#prefix' => '
', - // '#markup' => '

Hello !

', - // '#suffix' => '
', - // '#weight' => $form['field_identifiant']['#weight'], - // ); - // - -} - - - - From feae2e1f348fd703c7018a516d300cdc634b68b4 Mon Sep 17 00:00:00 2001 From: bachy Date: Thu, 3 Jan 2013 16:06:01 +0100 Subject: [PATCH 4/4] mini fixe Signed-off-by: bachy --- idmaterio.module | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/idmaterio.module b/idmaterio.module index 4295e7b5..a474c545 100644 --- a/idmaterio.module +++ b/idmaterio.module @@ -59,7 +59,7 @@ function computed_field_field_identifiant_compute(&$entity_field, $entity_type, } } -function computed_field_field_identifiant_display($field, $entity_field_item, $entity_lang, $langcode) { +function computed_field_field_identifiant_display($field, $entity_field_item, $entity_lang = "en", $langcode = "en") { return $entity_field_item['value']; } @@ -80,7 +80,7 @@ function computed_field_field_reference_materio_compute(&$entity_field, $entity_ } -function computed_field_field_reference_materio_display($field, $entity_field_item, $entity_lang, $langcode) { +function computed_field_field_reference_materio_display($field, $entity_field_item, $entity_lang = "en", $langcode = "en") { return $entity_field_item['value']; }