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é', ), /* What is this ? */ 'lieuAct' => array( 'label' => "Lieu d\'activté", 'fields' => array( 'interval' => array('value' => array('0', '1000')), 'textarea' => array('value' => null) ), 'famille' => 'entreprise', 'activated' => true, ), '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', ), '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', ), 'teff_entrep' => array( 'label' => "Tranche d'effectif de l'Entreprise", 'fields' => array( 'selectMultiple' => array( 'value' => array( 'NN' => "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( 'NN' => "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( 'intervalSelect' => array( 'value' => array( array(0, 15000), array(15000, 30000), array(30000, 75000), array(75000, 150000), array(150000, 750000), array(750000, 0), ) ) ), '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( 'I' => 'Inconnus', 'R' => 'Réels', 'E' => 'Estimés') ), ), '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( '' => 'Risque indéterminé', '00' => 'Aucun risque resencé', '10' => 'Présence d\'impayé(s)', '15' => 'Présence de privilèges', '23-29-39-43' => 'Risque moyen', '21-26-28' => 'Risque important', '31-50' => 'Risque très important', '24' => '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; } /** * Enregistre un critère et sa valeur * @param string $key * @param mixed $value * @param boolean $ex */ public function setCritere($key, $value, $ex = false) { //Remove critere for these values on all type of fields if ( in_array($value, array('', '-', null)) ) { unset($this->ciblage[$key]); return; } $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': //Check values break; } //Save the value if ($ex) { $this->ciblage[$key]['ex'] = $value; } else { $this->ciblage[$key]['in'] = $value; } $this->setSession(); } /** * 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 mixed $valeur */ public function unsetCritereValue($key, $valeur) { //@todo provisoir trouver une autre technique plus adapté. if(key_exists($key, $this->ciblage)) { $don = explode(',', $this->ciblage[$key]); foreach ($don as $val) { if($val == $valeur) $don[key($don)] = ''; else $new[] = $val; } if(count($new) > 0) { $don = implode(',', $new); if(!empty($don)) $this->ciblage[$key] = $don; } else { unset($this->ciblage[$key]); } $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; $this->setSession(); } /** * 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': // de X à X [unités] break; case 'tree': $action = ucfirst($this->fields[$name]['fields'][$firstType]['action']); return $this->{'getValueLabel'.$action}($values); //Recherche des valeurs break; } } return ''; } public function getInfoCritere() { } }