123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260 |
- <?php
- //Déclaration d'un item de menu dans le menu principal
- function dashboard_menu(&$menuItems){
- global $myUser;
- if(!$myUser->can('dashboard','read')) return;
- $menuItems[] = array(
- 'sort'=>3,
- 'url'=>'index.php?module=dashboard',
- 'label'=>'Dashboard',
- 'icon'=> 'far fa-object-ungroup',
- 'color'=> '#273c75'
- );
- }
- //Cette fonction va générer une page quand on clique sur Dashboard dans menu
- function dashboard_page(){
- global $_, $myUser;
- if(isset($_['module'])) return;
- $page = !isset($_['page']) ? 'list.dashboard' : $_['page'];
- $page = str_replace('..','',$page);
- $file = __DIR__.SLASH.'page.'.$page.'.php';
- if(!file_exists($file)) throw new Exception("Page ".$page." inexistante");
- require_once($file);
- }
- //Fonction executée lors de l'activation du plugin
- function dashboard_install($id){
- if($id != 'fr.core.dashboard') return;
- Entity::install(__DIR__);
- }
- //Fonction executée lors de la désactivation du plugin
- function dashboard_uninstall($id){
- if($id != 'fr.core.dashboard') return;
- Entity::uninstall(__DIR__);
- }
- //Déclaration des sections de droits du plugin
- Right::register('dashboard',array('label'=>'Gestion des droits sur le plugin Dashboard'));
- //Déclaration du menu de réglages
- function dashboard_menu_setting(&$settingMenu){
- global $myUser;
- if(!$myUser->can('dashboard','configure')) return;
- $settingMenu[]= array(
- 'sort' =>1,
- 'url' => 'setting.php?section=global.dashboard',
- 'icon' => 'fas fa-angle-right',
- 'label' => 'Dashboard'
- );
- }
- //Déclaration des pages de réglages
- function dashboard_content_setting(){
- global $_;
- if(file_exists(__DIR__.SLASH.'setting.'.$_['section'].'.php'))
- require_once(__DIR__.SLASH.'setting.'.$_['section'].'.php');
- }
- require_once(__DIR__.SLASH.'action.php');
- //Déclaration des settings de base
- //Types possibles : voir FieldType.class.php. Un simple string définit une catégorie.
- Configuration::setting('dashboard',array(
- "Général",
- //'dashboard_enable' => array("label"=>"Activer","type"=>"boolean"),
- ));
- function dashboard_application_bottom(){
- ?>
- <template id="dashboard-widget-template">
- <div class="dashboard-widget" data-id="{{id}}" data-width="{{width}}" data-height="{{height}}">
- <div class="dashboard-widget-header">
- <div class="widget-header-icon"><i class="fas fa-question"></i></div>
- <div class="widget-header-title">{{label}}</div>
- <ul class="widget-header-options"></ul>
- </div>
- <div class="dashboard-widget-content"></div>
- <div class="dashboard-widget-resize py-1 px-2"><i class="fas fa-chevron-right"></i></div>
- </div>
- </template>
- <!-- Modal Dashboard -->
- <div class="modal fade dashboard-modal" id="dashboard-modal" tabindex="-1" role="dialog" aria-hidden="true">
- <div class="modal-dialog modal-dialog-scrollable modal-lg" role="document">
- <div class="modal-content">
- <div class="modal-header">
- <h5 class="modal-title" id="exampleModalLabel">Configuration</h5>
- <button type="button" class="close" data-dismiss="modal" aria-label="Close">
- <span aria-hidden="true">×</span>
- </button>
- </div>
- <div class="modal-body p-0 overflow-hidden">
- <div class="container-fluid py-0 h-100">
- <div class="row h-100">
- <div class="col-md-3 border-right px-0 overflow-auto h-100 dashboard-configure-menu" id="dashboard-configure-menu">
- <ul class="nav nav-tabs flex-column dashboard-configure-menu rounded-0 border-0" id="dashboard-configure-menu" role="tablist" aria-orientation="vertical">
- <li data-menu='model' class="nav-item border-bottom">
- <a class="nav-link border-0 rounded-0 active" id="model-tab" data-toggle="tab" role="tab" aria-controls="model" aria-selected="true">
- <i class="far fa-window-maximize mr-1"></i>Modèle
- </a>
- </li>
- <li data-menu='properties' class="nav-item border-bottom">
- <a class="nav-link border-0 rounded-0" id="properties-tab" data-toggle="tab" role="tab" aria-controls="properties" aria-selected="false">
- <i class="fas fa-list-ul mr-1"></i>Propriétés
- </a>
- </li>
- <li data-menu='style' class="nav-item border-bottom">
- <a class="nav-link border-0 rounded-0" id="style-tab" data-toggle="tab" role="tab" aria-controls="style" aria-selected="false">
- <i class="fas fa-palette mr-1"></i>Style
- </a>
- </li>
- </ul>
- </div>
- <template id="configure-model">
- <ul id="widget-models" class="widget-models bg-light">
- <li data-model="{{model}}" class="shadow-sm bg-white hidden">
- <h3><div class="widget-model-chip" style="background-color: {{headerBackground
- }};color: {{iconColor}}"><i class="{{icon}}"></i></div> {{label}}</h3>
- <p>{{excerpt}}</p>
- <i onclick="event.stopPropagation();$(this).parent().find('.long-description').toggleClass('hidden')" title="plus d'information sur le widget" class="fas fa-info-circle widget-model-info"></i>
- <hr/>
- <div class="hidden long-description text-muted">{{description}}<br>
- Créé par <i class="fas fa-user"></i> {{creator}} le <i>{{created}}</i>
- </div>
- <div class="checked"><i class="fas fa-check"></i></div>
- </li>
- </ul>
- </template>
- <template id="properties-model">
- <div class="p-3">
- <h3>Propriétés</h3>
- <div id="dashboard-properties-form"></div>
- <div class="btn btn-primary mt-1" id="dashboard-properties-save">Enregistrer</div>
- </div>
- </template>
- <template id="configure-style">
- <div class="row">
- <div class="col">
- <table class="table" id="configure-style-table">
- <tbody>
- <tr>
- <th colspan="2" class="align-middle">En-tête</th>
- </tr>
- <tr>
- <td><input type="text" data-type="icon" id="widget-header-icon"></td>
- <td class="align-middle">Icône</td>
- </tr>
- <tr>
- <td><input type="text" data-type="color" id="widget-header-icon-color"></td>
- <td class="align-middle">Couleur Icône</td>
- </tr>
- <tr>
- <td><input type="text" data-type="color" id="widget-header-title-color"></td>
- <td class="align-middle">Couleur titre</td>
- </tr>
- <tr>
- <td><input type="text" data-type="color" id="widget-header-background"></td>
- <td class="align-middle">Couleur de fond</td>
- </tr>
- <tr>
- <th colspan="2" class="align-middle">Corps</th>
- </tr>
- <tr>
- <td><input type="text" data-type="color" id="widget-body-background"></td>
- <td class="align-middle">Couleur de fond</td>
- </tr>
- <tr>
- <td><input type="text" data-type="color" id="widget-body-color"></td>
- <td class="align-middle">Couleur texte</td>
- </tr>
- </tbody>
- </table>
- </div>
- <div class="col dashboard-container">
- <!-- -->
- <div class="dashboard-widget dashboard-widget-customizer widget-draggable widget-resizeable widget-removable ui-draggable">
- <div class="dashboard-widget-header" style="background-color: rgb(0, 123, 255);">
- <div class="widget-header-icon ui-draggable-handle"><i class="far fa-user"></i></div>
- <div class="widget-header-title ui-draggable-handle">Titre</div>
- <ul class="widget-header-options"><li class="widget-option-configure" title="Configurer"><i class="fas fa-ellipsis-v"></i></li><li class="widget-option-delete" title="Supprimer"><i class="fa fa-times"></i></li></ul>
- </div>
- <div class="dashboard-widget-content"><div class="text-center m-auto">Contenu</div></div>
- <div class="dashboard-widget-resize py-1 px-2"><i class="fas fa-chevron-right"></i></div>
- </div>
- <!-- -->
- </div>
- </div>
- </template>
- <div class="col-md-9 px-0 overflow-auto h-100 dashboard-configure-content" id="dashboard-configure-content">
-
- </div>
- </div>
- </div>
- </div>
- <div class="modal-footer">
- <button type="button" class="btn" data-dismiss="modal">Fermer</button>
- </div>
- </div>
- </div>
- </div>
- <?php
- }
- Plugin::addHook('widget',function(&$models){
- $model = new DashboardWidget();
- $model->icon = 'far fa-user';
- $model->headerBackground = 'rgb(0, 123, 255)';
- $model->description = 'Une Horloge toute couillone';
- $model->label = 'Horloge';
- $model->width = 3;
- $model->height = 3;
- $model->model = 'clock';
- $model->css = array(__DIR__.'/css/widget-clock.css?v='.time());
- $model->js = array(__DIR__.'/js/widget-clock.js?v='.time());
-
- $model->content = function(&$widget){
- if(empty($widget->meta['hour-format'])) $widget->meta['hour-format'] = 'H:i:s';
- $widget->content = '<div class="text-center m-auto widget-clock-content">'.date($widget->meta['hour-format']).'</div>';
- $widget->label = 'Horloge '.date($widget->meta['hour-format']);
- };
- $model->configure = function($widget){
- if(empty($widget->meta['hour-format'])) $widget->meta['hour-format'] = 'H:i:s';
- ?>
- <label>Format de l'heure : </label>
- <input class="form-control" type="text" id="hour-format" placeholder="H:i:s" value="<?php echo $widget->meta['hour-format']; ?>">
- <?php
- };
- $model->save = function($widget,$form){
- $widget->meta['hour-format'] = $form['hour-format'];
- $widget->save();
- };
- $models[$model->model] = $model;
- });
- //Déclation des assets
- Plugin::addCss("/css/main.css");
- Plugin::addCss("/css/component.css?v=2");
- Plugin::addJs("/js/main.js");
- Plugin::addJs("/js/dashboard.js?v=2");
- Plugin::addJs("/js/component.js?v=2");
- //Mapping hook / fonctions
- Plugin::addHook("install", "dashboard_install");
- Plugin::addHook("uninstall", "dashboard_uninstall");
- Plugin::addHook("menu_main", "dashboard_menu");
- Plugin::addHook("page", "dashboard_page");
- Plugin::addHook("menu_setting", "dashboard_menu_setting");
- Plugin::addHook("content_setting", "dashboard_content_setting");
- Plugin::addHook("application_bottom", "dashboard_application_bottom");
|