odea/library/Scores/Fields.php
2012-07-24 15:33:46 +00:00

1121 lines
37 KiB
PHP

<?php
class Scores_Fields
{
/**
* Fields options to display
* [name] => array(
* label =>
* fields => array(
* type => array()
* ...
* )
* famille =>
* activated =>
* title =>
* )
* )
*
* name : the key to retrieve field parameters
* label : the string to display as title
* famille : the key to identify where familly the field belongs to
* activated : true or false
* title : Text to display as info or help
*
* fields : define all different fields for the same element
* => type : which type of element (select, text, tree, ...), it's the key for array
* => value :
* => label (optional) :
* => class :
* @var array
*/
protected $fields = array
(
'siege' => array (
'label' => "Type d'établissement",
'fields' => array(
'select' => array('value' => array('1' => 'Sièges', '0' => 'Secondaires')),
),
'famille' => 'entreprise',
'activated' => true,
'title' => 'Aide',
),
'groupe' => array(
'label' => "Appartient à un groupe",
'fields' => array(
'select' => array('value' => array('1' => 'Oui', '0' => 'Non')),
),
'famille' => 'entreprise',
'activated' => true,
'title' => 'Possibilité de restreindre la sélection aux entreprises appartenant à un groupe',
),
'tel' => array(
'label' => 'Téléphone renseigné',
'fields' => array(
'select' => array('value' => array('1' => 'Oui', '0' => 'Non'))
),
'famille' => 'entreprise',
'activated' => true,
'title' => 'Possibilité de restreindre la sélection aux établissements ayant un numéro de téléphone renseigné',
),
'fax' => array(
'label' => 'Télécopie renseignée',
'fields' => array(
'select' => array('value' => array('1' => 'Oui', '0' => 'Non'))
),
'famille' => 'entreprise',
'activated' => true,
'title' => 'Possibilité de restreindre la sélection aux établissements ayant un numéro de télécopie renseigné',
),
'web' => array(
'label' => 'Site Web renseigné',
'fields' => array(
'select' => array('value' => array('1' => 'Oui', '0' => 'Non'))
),
'famille' => 'entreprise',
'activated' => true,
'title' => 'Possibilité de restreindre la sélection aux entreprises ayant un site web renseigné',
),
'mail' => array(
'label' => 'Email de contact renseigné',
'fields' => array(
'select' => array('value' => array('1' => 'Oui', '0' => 'Non'))
),
'famille' => 'entreprise',
'activated' => true,
'title' => 'Possibilité de restreindre la sélection aux établissements ayant une adresse email de contact renseignée',
),
'presentRcs' => array(
'label' => 'Etablissement présent au RNCS',
'fields' => array(
'select' => array('value' => array('1' => 'Oui', '0' => 'Non'))
),
'famille' => 'entreprise',
'activated' => true,
'title' => 'Inclure ou exclure les établissements présents au Registre National du Commerce et des Sociétés',
),
'adrDom' => array(
'label' => 'Adresse de domiciliation',
'fields' => array(
'select' => array('value' => array('1' => 'Oui', '0' => 'Non'))
),
'famille' => 'entreprise',
'activated' => true,
'title' => 'Inclure ou exclure les établissements situés à une adresse de domiciliation suspectée ou avérée',
),
'dirNom' => array(
'label' => 'Nom du principal dirigeant présent',
'fields' => array(
'select' => array('value' => array('1' => 'Oui', '0' => 'Non'))
),
'famille' => 'entreprise',
'activated' => true,
'title' => 'Inclure ou exclure les entreprises ayant un principal dirigeant renseigné',
),
'nbMPubli' => array(
'label' => 'Marchés publiques remportés',
'fields' => array(
'select' => array('value' => array('1' => 'Oui', '0' => 'Non'))
),
'famille' => 'entreprise',
'activated' => true,
'title' => 'Inclure/Exclure les entreprises ayant remportés des marchés publics. Une entreprise remportant des marchés publics est à jour de ses obligations fiscales et sociales, affirme sa capacité structurelle à répondre à la commande publique (capacité financière, personnel, encadrement, ...), dispose d\'une assurance pour les risques professionnels, a communiqué ses éléments financiers au pouvoir adjudicateur',
),
'dateCrea_ent' => array(
'label' => "Date de création de l'entreprise",
'fields' => array(
'intervalDate' => array('value' => null)
),
'famille' => 'entreprise',
'activated' => true,
'title' => 'Limiter la sélection aux entreprises créées entre 2 dates, avant une date ou après une date',
),
'dateCrea_etab' => array(
'label' => "Date de création de l'établissement",
'fields' => array(
'intervalDate' => array('value' => null )
),
'famille' => 'entreprise',
'activated' => true,
'title' => 'Limiter la sélection aux établissements créés entre 2 dates, avant une date ou après une date',
),
'action' => array(
'label' => 'Présence d\'actionnaires',
'fields' => array(
'select' => array('value' => array('1' => 'Oui', '0' => 'Non'))
),
'famille' => 'entreprise',
'activated' => true,
'title' => 'Inclure ou exclure de la sélection les entreprises ayant au moins un actionnaire de renseigné',
),
'nbActio' => array(
'label' => "Nombre d'actionnaires connus",
'fields' => array(
'interval' => array('value' => null)
),
'famille' => 'entreprise',
'activated' => true,
'title' => 'Limiter la sélection aux entreprises ayant de 1 à N actionnaire(s) renseignée(s)',
),
'participation' => array(
'label' => "Présence de participations",
'fields' => array(
'select' => array('value' => array('1' => 'Oui', '0' => 'Non'))
),
'famille' => 'entreprise',
'activated' => true,
),
'nbPart' => array(
'label' => 'Nombre de participations connues',
'fields' => array(
'interval' => array('value' => array('0', '1000'))
),
'famille' => 'entreprise',
'activated' => true,
'title' => 'Limiter la sélection aux entreprises ayant de 1 à N participation(s) renseignée(s)',
),
'ape_etab' => array(
'label' => "Activité de l'établissement (Code NAF)",
'fields' => array(
'tree' => array('value' => null, 'action' => 'naf', 'title' => "Arborescence de code NAF établissement"),
'text' => array('value' => null, 'label' => "Recherche de code NAF", 'title'=>"Sélection de code NAF établissement"),
),
'famille' => 'economique',
'activated' => true,
),
'ape_entrep' => array(
'label' => "Activité de l'entreprise (Code NAF)",
'fields' => array(
'tree' => array('value' => null, 'action' => 'naf', 'title' => "Arborescence de code NAF entreprise"),
'text' => array('value' => null, 'label' => "Recherche de code NAF", 'title'=>"Sélection de code NAF entreprise"),
),
'famille' => 'economique',
'activated' => true,
),
'NaceEtab' => array(
'label' => 'Code NACE de l\'établissement',
'fields' => array(
'text' => array('value' => null),
'textarea' => array('value' => null)
),
'famille' => 'economique',
'activated' => true,
'title' => 'Limiter la sélection aux établissements ayant des NACE spécifiques (Nomenclature d\'Activités Européenne)',
),
'NaceEntrep' => array(
'label' => 'Code NACE de l\'entreprise',
'fields' => array(
'text' => array('value' => null),
'textarea' => array('value' => null)
),
'famille' => 'economique',
'activated' => true,
'title' => 'Limiter la sélection aux entreprises ayant des NACE spécifiques (Nomenclature d\'Activités Européenne)',
),
'age_etab' => array(
'label' => 'Age de l\'établissement',
'fields' => array(
'interval' => array('value' => null)
),
'famille' => 'economique',
'activated' => true,
'title' => 'Limiter la sélection aux établissements ayant un age spécifique',
'unit' => 'an',
),
'age_entrep' => array(
'label' => 'Age de l\'entreprise',
'fields' => array(
'interval' => array('value' => null)
),
'famille' => 'economique',
'activated' => true,
'title' => 'Limiter la sélection aux entreprises ayant un age spécifique',
'unit' => 'an',
),
'teff_entrep' => array(
'label' => "Tranche d'effectif de l'Entreprise",
'fields' => array(
'selectMultiple' => array(
'value' => array(
'99' => "Unités non employeuses",
'0' => "0 salarié",
'1' => "1 ou 2 salarié(s)",
'2' => "3 à 5 salariés",
'3' => "6 à 9 salariés",
'11' => "10 à 19 salariés",
'12' => "20 à 49 salariés",
'21' => "50 à 99 salariés",
'22' => "100 à 199 salariés",
'31' => "200 à 249 salariés",
'32' => "250 à 499 salariés",
'41' => "500 à 999 salariés",
'42' => "1 000 à 1 999 salariés",
'51' => "2 000 à 4 999 salariés",
'52' => "5 000 à 9 999 salariés",
'53' => "10 000 salariés et plus",
),
),
),
'famille' => 'economique',
'activated' => true,
'title' => "Limiter la sélection aux entreprises ayant certaines tranches de salariés. Attention, pour les unités non employeuses il n'y a pas de salarié au cours de l'année de référence et pas d'effectif au 31/12 ; cette tranche peut contenir quelques effectifs inconnus. A contrario, pour la tranche 0 salarié il n'y a pas d'effectifs au 31/12 mais l'unité a employé des salariés au cours de l'année de référence",
),
'teff_etab' => array(
'label' => 'Tranche d\'effectif de l\'établissement',
'fields' => array(
'selectMultiple' => array(
'value' => array(
'99' => "Unités non employeuses",
'0' => "0 salarié",
'1' => "1 ou 2 salariés",
'2' => "3 à 5 salariés",
'3' => "6 à 9 salariés",
'11' => "10 à 19 salariés",
'12' => "20 à 49 salariés",
'21' => "50 à 99 salariés",
'22' => "100 à 199 salariés",
'31' => "200 à 249 salariés",
'32' => "250 à 499 salariés",
'41' => "500 à 999 salariés",
'42' => "1 000 à 1 999 salariés",
'51' => "2 000 à 4 999 salariés",
'52' => "5 000 à 9 999 salariés",
'53' => "10 000 salariés et plus",
)
),
),
'famille' => 'economique',
'activated' => true,
'title' => "Limiter la sélection aux établissements ayant certaines tranches de salariés. Attention, pour les unités non employeuses il n'y a pas de salarié au cours de l'année de référence et pas d'effectif au 31/12 ; cette tranche peut contenir quelques effectifs inconnus. A contrario, pour la tranche 0 salarié il n'y a pas d'effectifs au 31/12 mais l'unité a employé des salariés au cours de l'année de référence",
),
'nbEtab' => array(
'label' => 'Nombre d\'établissements',
'fields' => array(
'interval' => array('value' => array('0', '10000000'))
),
'famille' => 'economique',
'activated' => true,
'title' => 'Limiter la sélection aux entreprises ayant de 1 à N établissements',
),
'eff_entrep' => array(
'label' => "Effectif réel de l'entreprise",
'fields' => array(
'interval' => array('value' => array('0', '10000000'))
),
'famille' => 'economique',
'activated' => true,
'title' => 'Limiter la sélection aux entreprises ayant de X à Y salariés',
),
'eff_etab' => array(
'label' => "Effectif réel de l'établissement",
'fields' => array(
'interval' => array('value' => array('0', '10000000'))
),
'famille' => 'economique',
'activated' => true,
'title' => 'Limiter la sélection aux établissements ayant de X à Y salariés',
),
'capital' => array(
'label' => 'Capital de l\'entreprise',
'fields' => array(
'interval' => array( 'value' => array('0', '750000'))
),
'famille' => 'economique',
'activated' => true,
'title' => "Limiter la sélection aux entreprises disposant d'un capital donné",
),
//geographique
'geo' => array(
'label' => 'Localisation géographique',
'fields' => array(
'tree' => array('value' => null, 'action' => 'geographique', 'title' => "Arborescence géographique"),
'text' => array('value' => null, 'label' => "Recherche", 'title'=>"Recherche géographique"),
),
'famille' => 'geographique',
'activated' => true,
),
'geo_domtom' => array(
'label' => 'Exlcure les DOM-TOM',
'fields' => array(
'checkbox' => array('value' => '1'),
),
'famille' => 'geographique',
'activated' => true,
'title' => 'Exclure les établissements situés dans les DOM-TOM',
),
'geo_etranger' => array(
'label' => 'Exclure les sociétés étrangères',
'fields' => array(
'checkbox' => array('value' => '1'),
),
'famille' => 'geographique',
'activated' => true,
'title' => 'Exclure les entreprises dont l\'établissement siège est situé à l\'étranger',
),
'geo_corse' => array(
'label' => 'Exclure la corse',
'fields' => array(
'checkbox' => array('value' => '1'),
),
'famille' => 'geographique',
'activated' => true,
'title' => 'Exclure les établissements situés en région Corse',
),
'adr_reg' => array(
'label' => 'Liste code région',
'fields' => array(
'text' => array('value' => null),
'textarea' => array('value' => null)
),
'famille' => 'geographique',
'activated' => true,
'type' => 'textarea',
'class' => null,
'action' => 'geographique',
'title' => 'Localisation'
),
'zus' => array(
'label' => 'Zones Urbaines Sensibles',
'fields' => array(
'select' => array('value' => array('1' => 'Oui', '0' => 'Non')),
),
'famille' => 'geographique',
'activated' => true,
'type' => 'select',
'title' => "Inclure/Exclure les établissements situés en Zone Urbaine Sensible (ou ZUS). Les ZUS sont des territoire infra-urbain défini par les pouvoirs publics français bénéficiant d'aides spécifiques sous forme d'exonérations fiscales et sociales.",
/*
pour être la cible prioritaire de la politique de la ville.
La loi n° 96-987 du 14 novembre 1996 relative à la mise en œuvre du Pacte de relance pour la ville a défini dans son article 2
Les zones urbaines sensibles constituent un sous-ensemble de l'ensemble plus large des 2 500 quartiers prioritaires objet des contrats urbains de cohésion sociale (CUCS)3 qui ont succédé aux contrats de ville.',
*/
),
'zru' => array(
'label' => 'Zones de Redynamisation Urbaine',
'fields' => array(
'select' => array('value' => array('1' => 'Oui', '0' => 'Non')),
),
'famille' => 'geographique',
'activated' => true,
'type' => 'select',
'title' => "Inclure/Exclure les établissements situés en Zone de Redynamisation Urbaine (ou ZRU). Les ZRU sont un sous-ensemble des Zones Urbaines Sensibles et bénéficient d'aides spécifiques sous forme d'exonérations fiscales et sociales.",
),
'zfu' => array(
'label' => 'Zones Franches Urbaines',
'fields' => array(
'select' => array('value' => array('1' => 'Oui', '0' => 'Non')),
),
'famille' => 'geographique',
'activated' => true,
'type' => 'select',
'title' => "Inclure/Exclure les établissements situés en Zone Franche Urbaine (ou ZFU). Les ZFU sont un sous-ensemble des Zones Urbaines Sensibles et bénéficient d'aides spécifiques sous forme d'exonérations fiscales et sociales.",
),
'cucs' => array(
'label' => 'Contrats Urbains de Cohésion Sociale',
'fields' => array(
'select' => array('value' => array('1' => 'Oui', '0' => 'Non')),
),
'famille' => 'geographique',
'activated' => true,
'type' => 'select',
'title' => 'Inclure/Exclure les établissements situés en Contrats Urbains de Cohésion Sociale (ou CUCS).',
),
'zrr' => array(
'label' => 'Zones de Revitalisation Rurale',
'fields' => array(
'select' => array('value' => array('1' => 'Oui', '0' => 'Non')),
),
'famille' => 'geographique',
'activated' => true,
'type' => 'select',
'title' => 'Inclure/Exclure les établissements situés en Zone de Revitalisation Rurale (ou ZRR)',
),
'zafr' => array(
'label' => 'Zones d\'Aides à Finalités Régionales',
'fields' => array(
'select' => array('value' => array('1' => 'Oui', '0' => 'Non')),
),
'famille' => 'geographique',
'activated' => true,
'type' => 'select',
'title' => "Inclure/Exclure les établissements situés en Zone d'Aide à Finalité Régionale (ou ZAFR)",
),
/*
* Forme Juridique
*/
'cj' => array(
'label' => 'Forme Juridique',
'fields' => array(
'tree' => array('value' => null, 'action' => 'juridique', 'title' => "Arborescence des Formes Juridiques"),
'text' => array('value' => null, 'label' => "Recherche", 'title'=>"Recherche des Formes Juridiques"),
),
'famille' => 'juridique',
'activated' => true,
),
'actifEco' => array(
'label' => 'Établissement économiquement actif',
'fields' => array(
'select' => array('value' => array('1' => 'Oui', '0' => 'Non')),
),
'famille' => 'juridique',
'activated' => true,
'title' => 'Inclure/Exclure les établissements économiquement inactifs : Etablissements présumés fermés (vendus sans formalités), Pli Non Distribué (NPAI)',
),
'procolHisto' => array(
'label' => 'Présence d\'une procédure dans l\'historique',
'fields' => array(
'select' => array('value' => array('1' => 'Oui', '0' => 'Non')),
),
'famille' => 'juridique',
'activated' => true,
'title' => 'Inclure/Exclure les entreprises ayant déjà été en procédure collective',
),
'tvaIntraValide' => array(
'label' => 'Numéro de TVA intracommunautaire valide',
'fields' => array(
'select' => array('value' => array('1' => 'Oui', '0' => 'Non')),
),
'famille' => 'juridique',
'activated' => true,
'title' => 'Inclure/Exclure les entreprises dont le numéro de TVA intracommunautaire est valide (si non, exclusion d\'office des micro-entreprises fiscales type Auto-entrepreneur)',
),
'dateImmat' => array(
'label' => 'Date d\'immatriculation de l\'entreprise',
'fields' => array(
'intervalDate' => array('value' => null)
),
'famille' => 'juridique',
'activated' => true,
'title' => 'Limiter aux entreprises dont la date de création est comprise entre A et B',
),
//financier
'bilType' => array(
'label' => 'Derniers éléments financiers',
'fields' => array(
'selectMultiple' => array('value' => array(
'1' => 'Inconnus', // I
'2' => 'Réels', // R
'3' => 'Estimés') //E
),
),
'famille' => 'financier',
'activated' => true,
'title' => 'Limiter aux entreprises dont les derniers éléments financiers sont Réels, Estimés ou Inconnus',
),
'avisCs' => array(
'label' => 'Informations de paiements',
'fields' => array(
'selectMultiple' => array('value' => array(
'0' => 'Risque indéterminé',
'1' => 'Aucun risque resencé',
'2' => 'Présence d\'impayé(s)',
'3' => 'Présence de privilèges',
'4' => 'Risque moyen',
'5' => 'Risque important',
'6' => 'Risque très important',
'7' => 'Risque dans le groupe')
),
),
'famille' => 'financier',
'activated' => true,
),
'bilDuree' => array(
'label' => 'Durée du dernier bilan en mois',
'fields' => array(
'intervalSelect' => array(
'value' => array(
array(0, 5),
array(5, 10),
array(10, 15),
array(20, 23),
array(23, 0)
)
)
),
'famille' => 'financier',
'activated' => true,
'title' => 'Limiter aux entreprises dont la durée du dernier bilan est précisée',
),
'bilTca' => array(
'label' => 'Tranche de CA issue du bilan',
'fields' => array(
'selectMultiple' => array('value' => array(
'0' => 'Non déterminée',
'1' => 'de 500K€ à1M€',
'2' => 'de 1 à 2 ME',
'3' => 'de 2 à 5 ME',
'4' => 'de 5 à 10 ME',
'5' => 'de 10 à 20 ME',
'6' => 'de 20 à 50 ME',
'7' => '50 à 100 ME',
'8' => 'de 100 à 200 ME',
'9' => '+ de 200 ME'
)),
),
'famille' => 'financier',
'activated' => true,
'title' => "Limitation aux entreprises dont la dernière tranche de Chiffre d'Affaires est précisée (Réel ou Estimé)",
),
'bilAnnee' => array(
'label' => 'Dernière année de bilan',
'fields' => array(
'interval' => array('value' => array('0', '1000'))
),
'famille' => 'financier',
'activated' => true,
'title' => "Limitation aux entreprises dont la dernière année de bilan est précisée",
),
'bilCloture' => array(
'label' => 'Dernière date de clôture du bilan',
'fields' => array(
'interval' => array('value' => array('0', '1000'))
),
'famille' => 'financier',
'activated' => true,
'title' => "Limitation aux entreprises dont le dernier exercice comptable est situé entre 2 dates précises",
),
'bilEE' => array(
'label' => 'Total bilan (EE)',
'fields' => array(
'interval' => array('value' => array('0', '10000000'))
),
'famille' => 'financier',
'activated' => true,
'title' => "Limitation aux entreprises dont le poste EE (Montant du poste Total Bilan en Euros) est connu (Chiffres Réels uniquement)",
),
'bilFL' => array(
'label' => 'CA total (FL)',
'fields' => array(
'interval' => array('value' => array('0', '10000000'))
),
'famille' => 'financier',
'activated' => true,
'title' => "Limitation aux entreprises dont le poste FL (Montant du Chiffre d'Affaires en Euros) est connu (Chiffres Réels et Estimés)",
),
'bilFK' => array(
'label' => 'Chiffre d\'affaires Export (FK)',
'fields' => array(
'interval' => array('value' => array('0', '10000000'))
),
'famille' => 'financier',
'activated' => true,
'title' => "Limitation aux entreprises dont le poste FK (Montant du Chiffre d'Affaires Export en Euros) est connu (Chiffres Réels uniquement)",
),
'bilFR' => array(
'label' => 'Produits d\'Exploitation (FR)',
'fields' => array(
'interval' => array('value' => array('0', '10000000'))
),
'famille' => 'financier',
'activated' => true,
'type' => 'interval',
'class' => null,
'title' => "Limitation aux entreprises dont le poste FR (Montant des Produits d'Exploitation en Euros) est connu (Chiffres Réels uniquement)",
),
'bilGF' => array(
'label' => 'Charges d\'Exploitation (GF)',
'fields' => array(
'interval' => array('value' => array('0', '10000000'))
),
'famille' => 'financier',
'activated' => true,
'title' => "Limitation aux entreprises dont le poste GF (Montant des Charges d'Exploitation en Euros) est connu (Chiffres Réels uniquement)",
),
'bilGP' => array(
'label' => 'Charges Financières (GP)',
'fields' => array(
'interval' => array('value' => array('0', '10000000'))
),
'famille' => 'financier',
'activated' => true,
'title' => "Limitation aux entreprises dont le poste GP (Montant des Charges Financières en Euros) est connu (Chiffres Réels uniquement)",
),
'bilGW' => array(
'label' => 'R.C.A.I - Résultat courant av. impôt (GW)',
'fields' => array(
'interval' => array('value' => array('0', '10000000'))
),
'famille' => 'financier',
'activated' => true,
'title' => "Limitation aux entreprises dont le poste GW (Montant du Résultat Courant Avant Impôt en Euros) est connu (Chiffres Réels uniquement)",
),
'bilHD' => array(
'label' => 'Produits Exceptionnels (HD)',
'fields' => array(
'interval' => array('value' => array('0', '10000000'))
),
'famille' => 'financier',
'activated' => true,
'title' => "Limitation aux entreprises dont le poste HD (Montant des Produits Exceptionnels en Euros) est connu (Chiffres Réels uniquement)",
),
'bilHH' => array(
'label' => 'Charges Exceptionnels (HH)',
'fields' => array(
'interval' => array('value' => array('0', '10000000'))
),
'famille' => 'financier',
'activated' => true,
'title' => "Limitation aux entreprises dont le poste HH (Montant des Charges Exceptionnels en Euros) est connu (Chiffres Réels uniquement)",
),
'bilHL' => array(
'label' => 'Total des Produits (HL)',
'fields' => array(
'interval' => array('value' => array('0', '10000000'))
),
'famille' => 'financier',
'activated' => true,
'title' => "Limitation aux entreprises dont le poste HL (Montant du Total des Produits en Euros) est connu (Chiffres Réels uniquement)",
),
'bilHM' => array(
'label' => 'Total des Charges (HM)',
'fields' => array(
'interval' => array('value' => array('0', '10000000'))
),
'famille' => 'financier',
'activated' => true,
'title' => "Limitation aux entreprises dont le poste HM (Montant du Total des Charges en Euros) est connu (Chiffres Réels uniquement)",
),
'bilHN' => array(
'label' => 'Résultat (HN)',
'fields' => array(
'interval' => array('value' => array('0', '10000000'))
),
'famille' => 'financier',
'activated' => true,
'title' => "Limitation aux entreprises dont le poste HN (Montant du Résultat Net en Euros) est connu (Chiffres Réels uniquement)",
),
'bilYP' => array(
'label' => 'Effectif salarié (YP)',
'fields' => array(
'interval' => array('value' => array('0', '10000000'))
),
'famille' => 'financier',
'activated' => true,
'title' => "Limitation aux entreprises dont le poste YP (Effectif salarié de l'entreprise) est connu (Chiffres Réels uniquement)",
)
);
/**
* Save all information in this array
* The key NB is mandatory as this
* ['NB']['total'] => store the number of elements matches
* ['NB']['insee'] => store the number of elements matches which type is INSEE
* Other keys
* [key][in] => inclusion
* [key][ex] => exclusion
* @var array
*/
protected $ciblage;
protected $total = null;
protected $insee = null;
/**
*
* @param boolean $batch
*/
public function __construct($batch = false)
{
$session = new Zend_Session_Namespace('ciblage');
$this->ciblage = empty($session->ciblage) ? array() : $session->ciblage;
if (isset($this->ciblage['NB']['total'])) { $this->total = $this->ciblage['NB']['total']; }
if (isset($this->ciblage['NB']['insee'])) { $this->insee = $this->ciblage['NB']['insee']; }
if (isset($this->ciblage['NB'])) { unset($this->ciblage['NB']); }
}
/**
* Save data to session
*/
protected function setSession()
{
$session = new Zend_Session_Namespace('ciblage');
$this->ciblage['NB']['total'] = $this->total;
$this->ciblage['NB']['insee'] = $this->insee;
$session->ciblage = $this->ciblage;
}
/**
* After define criteres and no error return, set the session externaly
* @return void
*/
public function setCritereSession()
{
$this->setSession();
}
/**
* Enregistre un critère et sa valeur en effectuant les controls nécesaire
* @param string $key
* Critere key
* @param mixed $value
* Value(s)
* @param boolean $ex
* true for an exclude value
* @return boolean
* true if all is ok, false if the key doesn't exist or value is not correct
*/
public function setCritere($key, $value, $ex = false)
{
//Check if the key exist
if ( !in_array($key, $this->fields) ) {
return false;
}
//Remove critere for these values on all type of fields
if ( in_array($value, array('', '-', null)) ) {
unset($this->ciblage[$key]);
return true;
}
//Do some operation on value
$types = array_keys($this->fields[$key]['fields']);
if ( !is_array($value) && !in_array($types[0], array('select', 'checkbox', 'interval')) ) {
//Remove all space in string value
$value = str_replace(' ', '', $value);
//Try to detect separator and transform as array
//@todo : Schema a detecter
if ( preg_match_all('/([0-9A-Z]+)(?:,|;)?/', $value, $matches) ){
Zend_Registry::get('firebug')->info($matches);
$value = $matches[1];
}
//Add value to the existing
if (array_key_exists($key, $this->ciblage)) {
if ($ex) {
$value = array_merge($this->ciblage[$key]['ex'], $value);
} else {
$value = array_merge($this->ciblage[$key]['in'], $value);
}
}
}
if ($types[0]=='interval') {
$value = explode(',', $value);
}
//Remove duplicate values
if (is_array($value) ) {
$value = array_unique($value);
}
//Before to save the value
switch ( $types[0] ) {
case 'interval':
//@todo : Check Min Max
//@todo : Check Number => A préciser dans Fields
//@todo : Check Date => A préciser dans Fields
break;
case 'checkbox':
if ( $value==0 ) {
unset($this->ciblage[$key]);
return;
}
break;
case 'tree':
//@todo : Check if values exist
break;
}
//Save the value
if ($ex) {
Zend_Registry::get('firebug')->info('Exclude : ');
Zend_Registry::get('firebug')->info($value);
$this->ciblage[$key]['ex'] = $value;
} else {
$this->ciblage[$key]['in'] = $value;
Zend_Registry::get('firebug')->info('Include: ');
Zend_Registry::get('firebug')->info($value);
}
return true;
}
/**
* Définir les critères en une fois
* @param array $criteres Criteres as array with key => val
* @param boolean $inSession pour désactiver l'enregistrement en session
*/
public function setCriteres($criteres, $inSession = true)
{
$this->ciblage = $criteres;
if ( $inSession ) {
$this->setSession();
}
}
/**
* Désactivation d'un critère
* @param string $key
*/
public function unsetCritere($key)
{
if( key_exists($key, $this->ciblage) ) {
unset($this->ciblage[$key]);
$this->setSession();
}
}
/**
* Permet de supprimer une valeur dans une clef de session
* @param string $key
* @param int $pos
* @param boolean $ex
*/
public function unsetCritereValue($key, $pos, $ex = false)
{
if(key_exists($key, $this->ciblage)) {
if ($ex) {
$critereValues = $this->ciblage[$key]['ex'];
unset($critereValues[$pos]);
$this->ciblage[$key]['ex'] = array_values($critereValues);
} else {
$critereValues = $this->ciblage[$key]['in'];
unset($critereValues[$pos]);
$this->ciblage[$key]['in'] = array_values($critereValues);
}
$this->setSession();
}
}
/**
* Récupération de la valeur d'un critère
* @param string $key
*/
public function getCritere($key)
{
if(array_key_exists($key, $this->ciblage)) {
return $this->ciblage[$key];
}
return null;
}
/**
* Récupération des critères et de leurs valeurs
*/
public function getCriteres()
{
return $this->ciblage;
}
/**
* Définit un élément de comptage
* @param string $element
* @param integer $nb
*/
public function setNb($element, $nb)
{
$this->{$element} = $nb;
}
/**
* Récupére la valeur d'un élément de comptage
* @param string $element
*/
public function getNb($element)
{
return $this->{$element};
}
/**
* Suppression des critères de toutes une famille
* @param string $famille
*/
public function resetFamille($famille)
{
$reference = $this->getByFamille($famille);
foreach($this->ciblage as $name => $valeur) {
if($name != 'null') {
if(array_key_exists($name, $reference)) {
unset($this->ciblage[$name]);
}
}
}
$this->setSession();
}
/**
* Suppression de toutes les valeurs en session
*/
public function clearCiblage()
{
Zend_Session::namespaceUnset('ciblage');
}
public function getValues($val = null)
{
if ( $val === null ) {
$val = $this->getCriteres();
}
return $val;
}
/**
*
* @param unknown_type $name
*/
protected function getMinMax($name)
{
$MinMaxM = new Application_Model_MinMax();
$minmax = $MinMaxM->fetchAll($MinMaxM->select()->where('cle = ?', $name))->toArray();
return $minmax;
}
/**
*
*/
public function getFields() {
return $this->fields;
}
public function get($name)
{
if ($this->fields[$name]['activated'] == true)
return $this->fields[$name];
return null;
}
public function getByFamille($famille)
{
$section = array();
foreach($this->fields as $name => $item) {
if($item['famille'] == $famille) {
$section[$name] = $item;
}
}
return ($section);
}
public function getLabel($name)
{
return $this->fields[$name]['label'];
}
public function getValueLabelNaf($values)
{
$values = array_map(function($value){ return '"'.$value.'"'; }, $values);
$out = array();
$nafM = new Application_Model_Naf();
$sql = $nafM->select()->from($nafM, array('lib'))->where('code IN ('.join(',',$values).')');
$result = $nafM->fetchAll($sql)->toArray();
foreach ( $result as $elem ) {
$out[] = $elem['lib'];
}
return $out;
}
public function getValueLabelGeographique($values)
{
sort($values);
$out = array();
foreach ( $values as $item ) {
switch( substr($item,0,1) ) {
case 'C':
$communeM = new Application_Model_CodePostaux();
$sql = $communeM->select()->from($communeM, array('Commune'))->where('INSEE = ?', substr($item, 1));
$result = $communeM->fetchAll($sql)->toArray();
$out[] = $result[0]['Commune'];
break;
case 'D':
$departementsM = new Application_Model_Departements();
$sql = $departementsM->select()->from($departementsM, array('libdep'))->where('numdep = ?', substr($item, 1));
$result = $departementsM->fetchAll($sql)->toArray();
$out[] = $result[0]['libdep'];
break;
case 'R':
$regionsM = new Application_Model_Regions();
$sql = $regionsM->select()->from($regionsM, array('NCCENR'))->where('REGION = ?', substr($item,1));
$result = $regionsM->fetchAll($sql)->toArray();
$out[] = $result[0]['NCCENR'];
break;
}
}
return $out;
}
public function getValueLabelJuridique($values)
{
$values = array_map(function($value){ return '"'.$value.'"'; }, $values);
$out = array();
$fjM = new Application_Model_FormeJuridique();
$sql = $fjM->select()->from($fjM, array('fjLibelle'))->where('fjCode IN ('.join(',',$values).')');
$result = $fjM->fetchAll($sql)->toArray();
foreach ( $result as $elem ) {
$out[] = $elem['fjLibelle'];
}
return $out;
}
public function getValueLabel($name, $values)
{
if (count($values)>0 && array_key_exists($name, $this->fields)) {
$fieldsType = array_keys($this->fields[$name]['fields']);
$firstType = $fieldsType[0];
$fieldsValues = $this->fields[$name]['fields'][$firstType]['value'];
switch($firstType) {
case 'select':
case 'selectMultiple':
if (is_array($values)) {
$out = array();
foreach ( $values as $item ){
if (array_key_exists($item, $fieldsValues)) {
$out[] = $fieldsValues[$item];
}
}
return $out;
} else {
if (array_key_exists($values, $fieldsValues)) {
return $fieldsValues[$values];
}
}
break;
case 'interval':
$unit = '';
if (array_key_exists('unit', $this->fields[$name])) {
$unit = $this->fields[$name]['unit'];
}
//Max is not set
if ($values[1]=='') {
$label = "de ".$values[0]." ".$unit;
if ($values[0]>1) $label.= "s";
$label.=" et plus";
//Min is not set
} elseif ($values[0]=='') {
$label = "jusqu'à ".$values[1]." ".$unit;
if ($values[1]>1) $label.= "s";
//Min Max are set
} else {
$label = 'de '.number_format($values[0], null, ',', ' ')." ".$unit;
if ($values[0]>1) $label.= "s";
$label.= ' à '.number_format($values[1], null, ',', ' ')." ".$unit;
if ($values[1]>1) $label.= "s";
}
return $label;
break;
case 'intervalDate':
// du XX/XX/XXXX au XX/XX/XXXX
$date1 = substr($values[0],6,2).'/'.substr($values[0],4,2).'/'.substr($values[0],0,4);
$date2 = substr($values[1],6,2).'/'.substr($values[1],4,2).'/'.substr($values[1],0,4);
return 'du '.$date1.' au '.$date2;
break;
case 'tree':
$action = ucfirst($this->fields[$name]['fields'][$firstType]['action']);
return $this->{'getValueLabel'.$action}($values);
//Recherche des valeurs
break;
}
}
return '';
}
public function getInfoCritere()
{
}
}