diff --git a/.gitignore b/.gitignore index 6a5e7b48dfcd1ffac25b9c132aa7409bc1abf7ac..44d9c2322c1a350c8aa23e94c52a739fe755691a 100755 --- a/.gitignore +++ b/.gitignore @@ -11,4 +11,4 @@ apps/maarch_entreprise/xml/log4php.xml xdelete.sh core/Test/build/ apps/maarch_entreprise/tmp/* -/nbproject/private/ \ No newline at end of file +/nbproject/private/apps/maarch_entreprise/define_custom.php diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index 428d4cee848cd0e6c761d4a94550311c22a6ed50..b47432f6a2b959fbd23bc3b9e5fc1f02c59829a9 100755 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -34,11 +34,15 @@ job_php-7.0: - cd /var/www/html/MaarchCourrier - mkdir -p /var/www/html/MaarchCourrier - composer -n install - - npm install --production + - curl -sL https://deb.nodesource.com/setup_7.x | bash - + - apt-get install -yqq nodejs + - npm install npm@latest -g + - npm set registry https://registry.npmjs.org/ + - npm install - sed 's/<databaseserver>.*<\/databaseserver>/<databaseserver>postgres<\/databaseserver>/;s/<databasepassword>.*<\/databasepassword>/<databasepassword><\/databasepassword>/;s/<databasename>.*<\/databasename>/<databasename>MaarchCourrier<\/databasename>/;s/<databaseuser>.*<\/databaseuser>/<databaseuser>maarch<\/databaseuser>/' apps/maarch_entreprise/xml/config.xml.default > apps/maarch_entreprise/xml/config.xml - curl --location -s --output /usr/local/bin/phpunit https://phar.phpunit.de/phpunit.phar - chmod +x /usr/local/bin/phpunit #- cd App/MaarchRM - phpunit --coverage-text --colors=never -c phpunit.xml only: - - develop + - develop \ No newline at end of file diff --git a/apps/maarch_entreprise/Views/action-administration.component.html b/apps/maarch_entreprise/Views/action-administration.component.html index b66fb0e1a812a0402be5a09a35ccbd79b7834cb6..412a7f0c21ee5a205e3f2cf6e08de2f3854731b9 100755 --- a/apps/maarch_entreprise/Views/action-administration.component.html +++ b/apps/maarch_entreprise/Views/action-administration.component.html @@ -1,90 +1,123 @@ +<div class="page-header"> + <h1 *ngIf="!actionCreation">{{lang.actionModification}} <small>{{action.label_action}}</small></h1> + <h1 *ngIf="actionCreation">{{lang.actionCreation}} <small>{{action.label_action}}</small></h1> +</div> <div *ngIf="loading"> - <i class="fa fa-spinner fa-spin fa-5x" style="margin-left: 50%;margin-top: 16%;font-size: 8em"></i> + <md-spinner style="margin:auto;"></md-spinner> </div> <div *ngIf="!loading" class="container-fluid"> - <nav class="navbar navbar-default" style="font-size:17px !important;" id="toolBox"> - <div class="container-fluid"> - <div class="navbar-header"> - <a class="navbar-brand" routerLink="/administration/actions" style="cursor: pointer"> - <i class="fa fa-arrow-circle-left" title="{{lang.back}}"></i> - </a> - </div> - <div class="collapse navbar-collapse" id="bs-example-navbar-collapse-1"> - <ul class="nav navbar-nav navbar-right"> - - </ul> - </div> - </div> - </nav> - <h1 style="margin-top: 0"><i class="fa fa-exchange fa-2x"></i> {{lang.pageTitle}}</h1> - <div class="container-fluid" style="border-left:solid 1px white;border-right:solid 1px white;background-color: #CEE9F1;border-top: solid 2px #FDD16C;border-bottom: solid 2px #FDD16C;padding:10px;"> + <div class="container-fluid"> <div class="col-md-6 col-md-offset-3"> - <div *ngIf="action.is_system == true" class="alert alert-danger" role="alert"><b>{{lang.action}} {{lang.is_system}} !</b> {{lang.do_not_modify_unless_expert}}</div> + <div *ngIf="action.is_system == true" class="alert alert-danger" role="alert"><b>{{lang.isSytemAction}} !</b> {{lang.doNotModifyUnlessExpert}}</div> <form class="form-horizontal" (ngSubmit)="onSubmit()" #actionsFormUp="ngForm"> <div class="form-group"> <div class="col-sm-12"> - <div class="input-group"> - <span class="input-group-addon"><i aria-hidden="true" class="fa fa-tag" title="{{lang.desc}}"></i><sup class="mandatory" title="champ requis">*</sup></span> - <input [(ngModel)]="action.label_action" required class="form-control" name="action_name" id="action_name" title="{{lang.desc}}" type="text" placeholder="{{lang.desc}}" required> - </div> + <md-input-container> + <input mdInput [(ngModel)]="action.label_action" required name="action_name" id="action_name" title="{{lang.desc}}" type="text" placeholder="{{lang.desc}}" required> + </md-input-container> </div> </div> <div class="form-group"> <div class="col-sm-12"> - <div class="input-group"> - <span class="input-group-addon"><i aria-hidden="true" class="fa fa-check-circle" title="{{lang.associated_status}}"></i></span> - <select [(ngModel)]="action.id_status" class="forms-select form-control" name="status" id="status"> - <option *ngFor="let statut of statusList" [value]="statut.id">{{statut.label_status}}</option> - </select> - </div> + <md2-select + id="status" + name="status" + placeholder="{{lang.associatedStatus}}" + [(ngModel)]="action.id_status" + required + #searchStatus="ngModel"> + <md2-select-header> + <md-input-container> + <input mdInput name="search" + type="text" + placeholder="Filtre" + [(ngModel)]="_search" + autocomplete="off" + (focusout)="clearSearch()"/> + </md-input-container> + </md2-select-header> + <md2-option *ngFor="let statut of statusList | dataPipe : 'label_status' : _search" [value]="statut.id">{{statut.label_status}}</md2-option> + </md2-select> </div> </div> <div class="form-group"> <div class="col-sm-12"> - <div class="input-group"> - <span class="input-group-addon"><i aria-hidden="true" class="fa fa-retweet" title="{{lang.action_page}}"></i></span> - <select [(ngModel)]="action.action_page" class="forms-select form-control" name="action_page" id="action_page"> - <option title="{{action.desc}}" *ngFor="let action of actionPagesList.actionsPageList" value="{{action.name}}">{{action.label}}</option> - </select> - </div> + <md2-select + id="action_page" + name="action_page" + placeholder="{{lang.actionPage}}" + [(ngModel)]="action.action_page" + #searchAction="ngModel"> + <md2-select-header> + <md-input-container> + <input mdInput name="search" + type="text" + placeholder="Filtre" + [(ngModel)]="_search" + autocomplete="off" + (focusout)="clearSearch()"/> + </md-input-container> + </md2-select-header> + <md2-option *ngFor="let action of actionPagesList.actionsPageList | dataPipe : 'label' : _search" [value]="action.name">{{action.label}}</md2-option> + </md2-select> </div> </div> <div class="form-group"> <div class="col-sm-12"> - <div class="input-group"> - <span class="input-group-addon"><i aria-hidden="true" class="fa fa-code" title="{{lang.keyword}}"></i></span> - <select [(ngModel)]="action.keyword" class="forms-select form-control" name="keyword" id="keyword"> - <option title="{{keyword.desc}}" *ngFor="let keyword of keywordsList" value="{{keyword.value}}">{{keyword.label}}</option> - </select> - </div> + <md2-select + id="keyword" + name="keyword" + placeholder="{{lang.keyword}}" + [(ngModel)]="action.keyword" + #searchAction="ngModel"> + <!--<md2-select-header> + <md-input-container> + <input mdInput name="search" + type="text" + placeholder="Filtre" + [(ngModel)]="_search" + autocomplete="off" + (focusout)="clearSearch()"/> + </md-input-container> + </md2-select-header>--> + <md2-option *ngFor="let keyword of keywordsList | dataPipe : 'label' : _search" [value]="keyword.value">{{keyword.label}}</md2-option> + </md2-select> </div> </div> <div class="form-group"> - <div class="col-sm-6"> - <div class="input-group"> - <label class="form-control" for="history" title="{{lang.action_history_desc}}">{{lang.action_history}}</label> - <span class="input-group-addon"> - <input [(ngModel)]="action.history" name="history" id="history" type="checkbox"> - </span> - </div> - </div> - <div class="col-sm-6"> - <div class="input-group"> - <label class="form-control" for="is_folder_action" title="{{lang.is_folder_action_desc}}">{{lang.is_folder_action}}</label> - <span class="input-group-addon"> - <input [(ngModel)]="action.is_folder_action" name="is_folder_action" id="is_folder_action" type="checkbox"> - </span> + <div class="panel panel-default"> + <div class="panel-body"> + <div class="col-sm-6"> + <md-slide-toggle name="history" title="{{lang.actionHistoryDesc}}" id="history" color="primary" [(ngModel)]="action.history" [checked]="action.history == 'Y'">{{lang.actionHistory}}</md-slide-toggle> + </div> + <div class="col-sm-6"> + <md-slide-toggle name="is_folder_action" title="{{lang.isFolderActionDesc}}" id="is_folder_action" color="primary" [(ngModel)]="action.is_folder_action" [checked]="action.is_folder_action == 'Y'">{{lang.isFolderAction}}</md-slide-toggle> + </div> </div> </div> </div> - <div id="categoryAssociationList" class="form-group panel panel-default"> - <div class="col-sm-12 panel-heading" style="font-size: 14px;text-align:center;"> - <i title="{{lang.selectAll}}" class="fa fa-check-square-o selectAll" data-target="categorieslist" (click)="selectAll($event)"></i> <i title="{{lang.unselectAll}}" class="fa fa-square-o unselectAll" data-target="categorieslist" (click)="unselectAll($event)"></i> {{lang.choose_category_association }} - </div> - <div class="col-sm-12 panel-body"> - <select class="forms-select form-control" name="categorieslist[]" id="categorieslist" size="7" multiple="multiple" required> - <option *ngFor="let category of categoriesList" [selected]="category.selected" value="{{category.id}}">{{category.label}}</option> - </select> + <div class="form-group"> + <div class="col-sm-12"> + <md2-select + id="categorieslist" + name="categorieslist" + placeholder="{{lang.chooseCategoryAssociation}}" + [(ngModel)]="this.action.actionCategories" + required + multiple + #searchCat="ngModel"> + <!--<md2-select-header> + <md-input-container> + <input mdInput name="search" + type="text" + placeholder="Filtre" + [(ngModel)]="_search" + autocomplete="off" + (focusout)="clearSearch()"/> + </md-input-container> + </md2-select-header>--> + <md2-option *ngFor="let category of categoriesList | dataPipe : 'label' : _search" [value]="category.id">{{category.label}}</md2-option> + </md2-select> </div> </div> <div class="col-sm-12 panel-body" style="text-align:center;"> diff --git a/apps/maarch_entreprise/Views/actions-administration.component.html b/apps/maarch_entreprise/Views/actions-administration.component.html index 9a7f564f5f6d929782217aa816c2dc483ffc3192..9cd0c28fb3efb15fce5ff7e1c85f7cbad7f74c8c 100755 --- a/apps/maarch_entreprise/Views/actions-administration.component.html +++ b/apps/maarch_entreprise/Views/actions-administration.component.html @@ -1,49 +1,47 @@ +<div class="page-header"> + <h1>{{lang.administration}} {{lang.actions}} <small>{{data.length}} {{lang.actions}}</small></h1> +</div> <div *ngIf="loading"> - <i class="fa fa-spinner fa-spin fa-5x" style="margin-left: 50%;margin-top: 16%;font-size: 8em"></i> + <md-spinner style="margin:auto;"></md-spinner> </div> <div *ngIf="!loading" class="container-fluid"> - <h1 style="margin-top: 0"><i class="fa fa-exchange fa-2x"></i> {{lang.admin}} {{lang.actions}} : {{actions.length}} {{lang.actions}}</h1> - <nav class="navbar navbar-default" style="font-size:17px !important;" id="toolBox"> - <div class="container-fluid"> - <div class="navbar-header"> - <a class="navbar-brand" routerLink="/administration" style="cursor: pointer"> - <i class="fa fa-arrow-circle-left" title="{{lang.back}}"></i> - </a> - </div> - <div class="collapse navbar-collapse" id="bs-example-navbar-collapse-1"> - <ul class="nav navbar-nav navbar-right"> - <li style="cursor: pointer" routerLink="/administration/actions/new"> - <a data-toggle="modal" data-target="#manageSign" title="{{lang.new_action}}"><i class="fa fa-exchange"></i><sup><i class="fa fa-plus"></i></sup></a> - </li> - </ul> - </div> - </div> - </nav> <div class="col-md-12"> - <table id ="actionsTable" class="display" style="display:none;"> + <table id ="actionsTable" class="table table-hover table-condensed" [md2Data]="data | dataPipe : 'label_action' : search" #md2="md2DataTable" [sortBy]='id' [rowsPerPage]="10"> <thead> <tr> - <th style="width:5%;"><span>{{lang.id}}</span></th> - <th style="width:45%;"><span>{{lang.desc}}</span></th> - <th style="width:15%;"><span>{{lang.action_history}}</span></th> - <th style="width:15%;"><span>{{lang.isFolderAction}}</span></th> + <td colspan="4"> + <md2-pagination></md2-pagination> + </td> + <td style="text-align:right;"> + <md-input-container> + <input mdInput placeholder="{{lang.filterBy}} : {{lang.desc}}" class="md2-input" [(ngModel)]="search" /> + </md-input-container> + + <a class="text-primary" style="cursor: pointer" routerLink="/administration/actions/new" title="{{lang.new_action}}"><i class="fa fa-exchange fa-2x"></i><sup><i class="fa fa-plus"></i></sup></a> + </td> + </tr> + <tr> + <th style="width:5%;" md2SortBy="id"><span>{{lang.id}}</span></th> + <th style="width:45%;" md2SortBy="label_action"><span>{{lang.desc}}</span></th> + <th style="width:15%;" md2SortBy="history"><span>{{lang.actionHistory}}</span></th> + <th style="width:15%;" md2SortBy="is_folder_action"><span>{{lang.isFolderAction}}</span></th> <th style="width:30%;"><span> </span></th> </tr> </thead> <tbody> - <tr *ngFor="let action of actions" id="{{action.id}}"> - <td style="width:5%;"> {{action.id}} </td> - <td style="width:45%;"> {{action.label_action}} </td> - <td style="width:15%;" *ngIf="action.history == 'N'"> {{lang.no}} </td> - <td style="width:15%;" *ngIf="action.history == 'Y'"> {{lang.yes}} </td> - <td style="width:15%;" *ngIf="action.is_folder_action == 'Y'"> {{lang.yes}} </td> - <td style="width:15%;" *ngIf="action.is_folder_action == 'N'"> {{lang.no}} </td> - <td style="width:30%;" style="text-align:right;"> + <tr *ngFor="let action of md2.data"> + <td style="width:5%;vertical-align:middle;"> {{action.id}} </td> + <td style="width:45%;vertical-align:middle;"> {{action.label_action}} </td> + <td style="width:15%;vertical-align:middle;" *ngIf="action.history == 'N'"> {{lang.no}} </td> + <td style="width:15%;vertical-align:middle;" *ngIf="action.history == 'Y'"> {{lang.yes}} </td> + <td style="width:15%;vertical-align:middle;" *ngIf="action.is_folder_action == 'Y'"> {{lang.yes}} </td> + <td style="width:15%;vertical-align:middle;" *ngIf="action.is_folder_action == 'N'"> {{lang.no}} </td> + <td style="width:30%;vertical-align:middle;" style="text-align:right;"> <div class="btn-group" role="group" aria-label="..."> <button routerLink="/administration/actions/{{action.id}}" type="button" class="btn btn-default" title="{{lang.update}}"> <a><i style="cursor:pointer" class="fa fa-edit"></i></a> </button> - <button [disabled]="action.is_system == 'Y'" type="button" class="btn btn-default" title="{{lang.delete}}" (click)="deleteAction(action.id)"> + <button [disabled]="action.is_system == 'Y'" type="button" class="btn btn-default" title="{{lang.delete}}" (click)="deleteAction(action)"> <a><i style="cursor:pointer;color: #D9534F" class="fa fa-trash"></i></a> </button> </div> diff --git a/apps/maarch_entreprise/Views/administration.component.html b/apps/maarch_entreprise/Views/administration.component.html index b3044014dcab774dd0d84ab095da021f7b7e9d9b..f07accb215832169886d6dfe19c99cd249f8dadd 100755 --- a/apps/maarch_entreprise/Views/administration.component.html +++ b/apps/maarch_entreprise/Views/administration.component.html @@ -1,34 +1,26 @@ +<div class="page-header"> + <h1 style="margin-top: 0">{{lang.administration}}</h1> +</div> <div *ngIf="loading"> - <i class="fa fa-spinner fa-spin fa-5x" style="margin-left: 50%;margin-top: 16%;font-size: 8em"></i> + <md-spinner style="margin:auto;"></md-spinner> </div> -<div *ngIf="!loading" class="container-fluid"> - <h1 style="margin-top: 0"><i class="fa fa-cogs fa-2x"></i> {{lang.administration}}</h1> - <div class="row row-eq-height"> - <div *ngIf="applicationServices[0]" class="col-md-12 servicesDiv"> - <h2 class="administrationTitle">{{lang.application}}</h2> - <div class="content"> - <div *ngFor="let appService of applicationServices" class="admin_item" title="{{appService.comment}}" (click)="goToSpecifiedAdministration(appService)"> - <div> - <i class="{{appService.style}} fa-4x"></i> - </div> - <div> - <strong>{{appService.name}}</strong> - </div> - </div> - </div> - </div> - <div *ngIf="modulesServices[0]" class="col-md-12 servicesDiv"> - <h2 class="administrationTitle">{{lang.modules}}</h2> - <div class="content"> - <div *ngFor="let modService of modulesServices" class="admin_item" title="{{modService.comment}}" (click)="goToSpecifiedAdministration(modService)"> - <div> - <i class="{{modService.style}} fa-4x"></i> - </div> - <div> - <strong>{{modService.name}}</strong> - </div> - </div> - </div> - </div> +<div *ngIf="!loading" class="container-fluid" style="color:#666;"> + <div class="col-md-12"> + <md-tab-group> + <md-tab label="{{lang.application}}"> + <md-grid-list cols="6" rowHeight="2:1"> + <md-grid-tile *ngFor="let appService of applicationServices"> + <button md-button tooltip="{{appService.comment}}" tooltip-delay="1000" (click)="goToSpecifiedAdministration(appService)"><i class="{{appService.style}} fa-4x"></i><br/>{{appService.name}}</button> + </md-grid-tile> + </md-grid-list> + </md-tab> + <md-tab label="{{lang.modules}}"> + <md-grid-list cols="6" rowHeight="2:1"> + <md-grid-tile *ngFor="let modService of modulesServices"> + <button md-button tooltip="{{modService.comment}}" tooltip-delay="1000" (click)="goToSpecifiedAdministration(modService)"><i class="{{modService.style}} fa-4x"></i><br/>{{modService.name}}</button> + </md-grid-tile> + </md-grid-list> + </md-tab> + </md-tab-group> </div> </div> diff --git a/apps/maarch_entreprise/Views/header.component.html b/apps/maarch_entreprise/Views/header.component.html index bbbd7325debea3d95ffecef337f5985089aff7d4..33828d8a85268982dd4dd369629c6a61c4a05b30 100755 --- a/apps/maarch_entreprise/Views/header.component.html +++ b/apps/maarch_entreprise/Views/header.component.html @@ -1,72 +1,53 @@ -<nav id="headerV2" class="navbar navbar-default"> - <div class="container-fluid"> - <!-- Brand and toggle get grouped for better mobile display --> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#bs-example-navbar-collapse-1" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <a id="headerLogo" class="navbar-brand" href="index.php"></a> - </div> - - <!-- Collect the nav links, forms, and other content for toggling --> - <div class="collapse navbar-collapse" id="bs-example-navbar-collapse-1"> - <form class="navbar-form navbar-left"> - <div class="form-group"> - <div class="input-group"> - <div class="input-group-btn"> - <button type="button" class="btn btn-default dropdown-toggle" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false"><span class="fa fa-bars"></span> Courriers</button> - <ul class="dropdown-menu"> - <li><a href="#">Courriers</a></li> - <li><a href="#">Contacts</a></li> - <li><a href="#">Pièces jointes</a></li> - <li role="separator" class="divider"></li> - <li><a href="#">Globale</a></li> - </ul> - </div><!-- /btn-group --> - <input style="width:400px;" type="text" class="form-control" placeholder="Search for..."> - <span class="input-group-btn"> - <button class="btn btn-default" type="button"><i class="fa fa-search"></i></button> - </span> - </div><!-- /input-group --> - </div> - </form> - <ul class="nav navbar-nav navbar-right"> - <li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-haspopup="true" aria-expanded="false"><i class="fa fa-gears fa-2x"></i> <span class="caret"></span></a> - <ul class="dropdown-menu"> - <li><a href="#">Gestion utlisateurs</a></li> - <li><a href="#">Gestion groupes</a></li> - <li><a href="#">Gestion statuts</a></li> - <li><a href="#">...</a></li> - <li role="separator" class="divider"></li> - <li><a href="#">Panneau d'administration</a></li> - </ul> - </li> - <li class="dropdown" id="headerNotification"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-haspopup="true" aria-expanded="false"><i class="fa fa-bell fa-2x"></i><sup class="notification"><span color="red" class="badge">5</span></sup> <span class="caret"></span></a> - <ul class="dropdown-menu"> - <li class="alert-info"><a><b>3</b> nouveau(x) courrier(s) dans <i class="link">courrier à traiter</i></a></li> - <li class="alert-info"><a><b class="link">2017/A/123</b> nouvelle note ajoutée</a></li> - <li class="alert-warning"><a><b class="link">2017/A/123</b> arrive bientôt à échéance ! <i class="badge">1 jour(s)</i></a></li> - <li class="alert-warning"><a><b class="link">2017/A/21</b> arrive bientôt à échéance ! <i class="badge">2 jour(s)</i></a></li> - <li class="alert-danger"><a><b class="link">2017/A/21</b> est arrivé à échéance ! <i class="badge">- 4 jour(s)</i></a></li> - <li role="separator" class="divider"></li> - <li><a href="#">Voir la liste des notifications</a></li> - </ul> - </li> - <li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-haspopup="true" aria-expanded="false"><i class="fa fa-user fa-2x"></i> <span class="caret"></span></a> - <ul class="dropdown-menu"> - <li><a href="#">Mon profile</a></li> - <li role="separator" class="divider"></li> - <li><a href="#">Déconnexion</a></li> - </ul> - </li> - </ul> - </div><!-- /.navbar-collapse --> - </div><!-- /.container-fluid --> -</nav> -<router-outlet></router-outlet> \ No newline at end of file +<md-toolbar color="primary"> + <button tooltip="Menu" tooltip-delay="1000" md-button mdInput [mdMenuTriggerFor]="mySetting">{{applicationName}}</button> + <span id="globalSearch"> + <form class="example-form"> + <md-input-container> + <button md-button mdPrefix [mdMenuTriggerFor]="searchTarget"><i class="fa fa-bars fa-2x"></i></button> + <input type="tel" mdInput placeholder="Rechercher dans : global"> + </md-input-container> + </form> + </span> + <span style="flex: 1 1 auto;"></span> + <button tooltip="Administration" tooltip-delay="1000" md-icon-button [mdMenuTriggerFor]="myAdmin"> + <i class="fa fa-cogs fa-2x"></i> + </button> + <button tooltip="Mes notifications" tooltip-delay="1000" md-icon-button [mdMenuTriggerFor]="myNotif"> + <i class="fa fa-bell fa-2x"></i> + <sub class="badge text-warning">0</sub> + </button> + <button tooltip="Mes paramètres" tooltip-delay="1000" md-icon-button [mdMenuTriggerFor]="myProfil"> + <i class="fa fa-user fa-2x"></i> + </button> + <md-menu #mySetting="mdMenu"> + <button *ngFor="let menu of menuList" routerLink="{{menu.link}}" md-menu-item> + <span><i class="fa {{menu.icon}}"></i> {{menu.label}}</span> + </button> + </md-menu> + <md-menu #myNotif="mdMenu"> + <button md-menu-item disabled> + <span style="opacity:0.5;"><i class="fa fa-times"></i> Aucune notification</span> + </button> + </md-menu> + <md-menu #myProfil="mdMenu"> + <button *ngFor="let profil of profilList" routerLink="{{profil.link}}" md-menu-item> + <span><i class="fa {{profil.style}}"></i> {{profil.label}}</span> + </button> + </md-menu> + <md-menu #myAdmin="mdMenu"> + <button *ngFor="let admin of adminList" routerLink="{{admin.servicepage}}" tooltip="{{admin.comment}}" tooltip-position="before" tooltip-delay="1000" md-menu-item [disabled]="admin.angular == 'false'"> + <span><i class="fa {{admin.style}}"></i> {{admin.name}}</span> + </button> + <button *ngFor="let adminMod of adminListModule" routerLink="{{adminMod.servicepage}}" tooltip="{{adminMod.comment}}" tooltip-position="before" tooltip-delay="1000" md-menu-item [disabled]="adminMod.angular == 'false'"> + <span><i class="fa {{adminMod.style}}"></i> {{adminMod.name}}</span> + </button> + </md-menu> + <md-menu #searchTarget="mdMenu"> + <button md-menu-item> + <span>Courriers</span> + </button> + <button md-menu-item> + <span>Contacts</span> + </button> + </md-menu> +</md-toolbar> diff --git a/apps/maarch_entreprise/Views/history-administration.component.html b/apps/maarch_entreprise/Views/history-administration.component.html new file mode 100644 index 0000000000000000000000000000000000000000..dd807a1db4cc1559bdb5912c8a111fdd1a81a0b9 --- /dev/null +++ b/apps/maarch_entreprise/Views/history-administration.component.html @@ -0,0 +1,84 @@ +<div class="page-header"> + <h1>{{lang.administration}} {{lang.history}} <small>{{data.length}} {{lang.entries}}</small></h1> +</div> +<div *ngIf="loading"> + <md-spinner style="margin:auto;"></md-spinner> +</div> +<div *ngIf="!loading" class="container-fluid"> + <div class="col-md-12"> + <table id="usersTable" class="table table-hover table-condensed" [md2Data]="data | dataPipe : 'info' : search | dataPipe : 'user_id' : filterUser | dataPipe : 'event_type' : filterEventType" + #md2="md2DataTable" [sortBy]='event_date' [rowsPerPage]="10"> + <thead> + <tr> + <td colspan="5"> + <md2-pagination></md2-pagination> + </td> + <td style="text-align:right;"> + <md2-datepicker name="mindate" placeholder="{{lang.dataOfMonth}} :" type="month" [(ngModel)]="minDate" #minDateControl="ngModel" + (change)="refreshHistory()"> + </md2-datepicker> + + </td> + </tr> + <tr class="filters"> + <td colspan="6"> + <md2-accordion> + <md2-accordion-tab> + <md2-accordion-header class="text-primary">{{lang.filterBy}} : </md2-accordion-header> + <div class="panel panel-default"> + <div class="panel-body"> + <div class="col-sm-4"> + <md-input-container> + <input mdInput placeholder="{{lang.desc}}" [(ngModel)]="search" /> + </md-input-container> + </div> + <div class="col-sm-4"> + <md2-select placeholder="Utilisateur cible" [(ngModel)]="filterUser" #filterUsersSelect="ngModel" style="padding:0px;padding-top: 15px;"> + <md2-select-header> + <md-input-container> + <input mdInput name="search" type="text" placeholder="Filtre" [(ngModel)]="_search" autocomplete="off" /> + </md-input-container> + </md2-select-header> + <md2-option style="font-style:italic;color:grey;">{{lang.noSelection}}</md2-option> + <md2-option *ngFor="let filter of filterUsers | dataPipe : 'user_id' : _search" [value]="filter.user_id">{{filter.user_id}}</md2-option> + </md2-select> + </div> + <div class="col-sm-4"> + <md2-select placeholder="Evenement cible" [(ngModel)]="filterEventType" #filterUsersSelect="ngModel" style="padding:0px;padding-top: 15px;"> + <md2-select-header> + <md-input-container> + <input mdInput name="search" type="text" placeholder="Filtre" [(ngModel)]="_search" autocomplete="off" /> + </md-input-container> + </md2-select-header> + <md2-option style="font-style:italic;color:grey;">{{lang.noSelection}}</md2-option> + <md2-option *ngFor="let filter of filterEventTypes | dataPipe : 'event_type' : _search" [value]="filter.event_type">{{filter.event_type}}</md2-option> + </md2-select> + </div> + </div> + </div> + </md2-accordion-tab> + </md2-accordion> + </td> + </tr> + <tr> + <th md2SortBy="event_date" style="width:10%;">{{lang.date}}</th> + <th md2SortBy="event_type" style="width:10%;">{{lang.event}}</th> + <th md2SortBy="user_id" style="width:15%;">{{lang.user}}</th> + <th md2SortBy="table_name" style="width:15%;">{{lang.table}}</th> + <th md2SortBy="info" style="width:40%;">{{lang.desc}}</th> + <th md2SortBy="info" style="width:10%;">{{lang.ip}}</th> + </tr> + </thead> + <tbody> + <tr *ngFor="let history of md2.data"> + <td style="vertical-align:middle;">{{history.event_date | date : "dd/MM/y HH:mm"}}</td> + <td style="vertical-align:middle;">{{history.event_type}}</td> + <td style="vertical-align:middle;">{{history.user_id}}</td> + <td style="vertical-align:middle;">{{history.table_name}}</td> + <td style="vertical-align:middle;">{{history.info}}</td> + <td style="vertical-align:middle;">{{history.remote_ip}}</td> + </tr> + </tbody> + </table> + </div> +</div> diff --git a/apps/maarch_entreprise/Views/historyBatch-administration.component.html b/apps/maarch_entreprise/Views/historyBatch-administration.component.html new file mode 100644 index 0000000000000000000000000000000000000000..9b471ea567e2785ddfd361272399a19163a767d6 --- /dev/null +++ b/apps/maarch_entreprise/Views/historyBatch-administration.component.html @@ -0,0 +1,76 @@ +<div class="page-header"> + <h1>{{lang.administration}} {{lang.historyBatch}} <small>{{data.length}} {{lang.entries}}</small></h1> +</div> +<div *ngIf="loading"> + <md-spinner style="margin:auto;"></md-spinner> +</div> +<div *ngIf="!loading" class="container-fluid"> + <div class="col-md-12"> + <table id="usersTable" class="table table-hover table-condensed" [md2Data]="data | dataPipe : 'info' : search | dataPipe : 'user_id' : filterUser | dataPipe : 'event_type' : filterEventType" + #md2="md2DataTable" [sortBy]='event_date' [rowsPerPage]="10"> + <thead> + <tr> + <td colspan="5"> + <md2-pagination></md2-pagination> + </td> + <td style="text-align:right;"> + <md2-datepicker name="mindate" placeholder="{{lang.dataOfMonth}} :" type="month" [(ngModel)]="minDate" #minDateControl="ngModel" + (change)="refreshHistory()"> + </md2-datepicker> + + </td> + </tr> + <tr class="filters"> + <td colspan="6"> + <md2-accordion> + <md2-accordion-tab> + <md2-accordion-header class="text-primary">{{lang.filterBy}} : </md2-accordion-header> + <div class="panel panel-default"> + <div class="panel-body"> + <div class="col-sm-4"> + <md-input-container> + <input mdInput placeholder="{{lang.desc}}" [(ngModel)]="search" /> + </md-input-container> + </div> + <div class="col-sm-4"> + <md2-select placeholder="Module cible" [(ngModel)]="filterModule" #filterUsersSelect="ngModel" style="padding:0px;padding-top: 15px;"> + <md2-select-header> + <md-input-container> + <input mdInput name="search" type="text" placeholder="Filtre" [(ngModel)]="_search" autocomplete="off" /> + </md-input-container> + </md2-select-header> + <md2-option style="font-style:italic;color:grey;">{{lang.noSelection}}</md2-option> + <md2-option *ngFor="let filter of filterModules | dataPipe : 'module_name' : _search" [value]="filter.module_name">{{filter.module_name}}</md2-option> + </md2-select> + </div> + <div class="col-sm-4"> + + </div> + </div> + </div> + </md2-accordion-tab> + </md2-accordion> + </td> + </tr> + <tr> + <th md2SortBy="batch_id" style="width:5%;">{{lang.id}}</th> + <th md2SortBy="event_date" style="width:15%;">{{lang.date}}</th> + <th md2SortBy="total_processed" style="width:15%;">{{lang.totalProcessed}}</th> + <th md2SortBy="total_errors" style="width:15%;">{{lang.totalErrors}}</th> + <th md2SortBy="info" style="width:40%;">{{lang.desc}}</th> + <th md2SortBy="module_name" style="width:10%;">{{lang.module}}</th> + </tr> + </thead> + <tbody> + <tr *ngFor="let history of md2.data"> + <td style="vertical-align:middle;">{{history.batch_id}}</td> + <td style="vertical-align:middle;">{{history.event_date | date : "dd/MM/y HH:mm"}}</td> + <td style="vertical-align:middle;">{{history.total_processed}}</td> + <td style="vertical-align:middle;">{{history.total_errors}}</td> + <td style="vertical-align:middle;">{{history.info}}</td> + <td style="vertical-align:middle;">{{history.module_name}}</td> + </tr> + </tbody> + </table> + </div> +</div> diff --git a/apps/maarch_entreprise/Views/parameter-administration.component.html b/apps/maarch_entreprise/Views/parameter-administration.component.html index f22e8b2562a991b28df3389e30c3169edba0b801..ce9f5704a3fe8b59042f3cf753a8889a6008c0e6 100755 --- a/apps/maarch_entreprise/Views/parameter-administration.component.html +++ b/apps/maarch_entreprise/Views/parameter-administration.component.html @@ -1,64 +1,61 @@ -<div id="resultInfo" class="fade" style="display:none;"> - {{resultInfo}} +<div class="page-header"> + <h1 *ngIf="!creationMode">{{lang.parameterModification}} <small>{{parameter.id}}</small></h1> + <h1 *ngIf="creationMode">{{lang.parameterCreation}} <small>{{parameter.id}}</small></h1> </div> <div *ngIf="loading"> - <i class="fa fa-spinner fa-spin fa-5x" style="margin-left: 50%;margin-top: 16%;font-size: 8em"></i> + <md-spinner style="margin:auto;"></md-spinner> </div> <div *ngIf="!loading" class="container-fluid"> - <nav class="navbar navbar-default" style="font-size:17px !important;" id="toolBox"> - <div class="container-fluid"> - <div class="navbar-header"> - <a class="navbar-brand" routerLink="/administration/parameters" style="cursor: pointer"> - <i class="fa fa-arrow-circle-left" title="{{lang.back}}"></i> - </a> - </div> - <div class="collapse navbar-collapse" id="bs-example-navbar-collapse-1"> - <ul class="nav navbar-nav navbar-right"> - - </ul> - </div> - </div> - </nav> - <h1 style="margin-top: 0"><i class="fa fa-check-wrench fa-2x"></i> {{pageTitle}}</h1> - <div class="container-fluid" style="border-left:solid 1px white;border-right:solid 1px white;background-color: #CEE9F1;border-top: solid 2px #FDD16C;border-bottom: solid 2px #FDD16C;padding:10px;"> + <div class="container-fluid"> <div class="col-md-6 col-md-offset-3"> <form class="form-horizontal" (ngSubmit)="onSubmit()" #parameterFormUp="ngForm"> <div class="form-group"> <div class="col-sm-12"> - <div class="input-group"> - <span class="input-group-addon"><i aria-hidden="true" class="fa fa-hashtag" title="{{this.lang.identifier}}"></i><sup class="mandatory" title="champ requis">*</sup></span> - <input [(ngModel)]="parameter.id" [disabled]="!creationMode" required class="form-control" name="id" id="id" title="{{lang.desc}}" type="text" placeholder="{{this.lang.identifier}}" required> - </div> + <md-input-container> + <input mdInput [(ngModel)]="parameter.id" [disabled]="!creationMode" required name="id" id="id" title="{{lang.id}}" type="text" placeholder="{{lang.id}}" required> + </md-input-container> </div> </div> <div class="form-group"> <div class="col-sm-12"> - <div class="input-group"> - <span class="input-group-addon"><i aria-hidden="true" class="fa fa-tag" title="{{this.lang.description}}"></i><sup class="mandatory" title="champ requis"></sup></span> - <input [(ngModel)]="parameter.description" class="form-control" name="description" id="description" title="{{lang.description}}" type="text" placeholder="{{this.lang.description}}"> - </div> + <md-input-container> + <input mdInput [(ngModel)]="parameter.description" name="description" id="description" title="{{lang.desc}}" type="text" placeholder="{{lang.desc}}"> + </md-input-container> </div> </div> <div class="form-group"> - <div class="col-sm-12"> - <div class="input-group"> - <span class="input-group-addon"><i aria-hidden="true" class="fa fa-bullseye" title="{{this.lang.type}}"></i><sup class="mandatory" title="champ requis"></sup></span> - <select name="type" id="type" [disabled]="!creationMode" [(ngModel)]="type" class="forms-select form-control" #selectType> - <option value="string" [(ngValue)]="string">{{this.lang.string}}</option> - <option value="int" [(ngValue)]="int">{{this.lang.integer}}</option> - <option value="date" [(ngValue)]="date">{{this.lang.date}}</option> - </select> - </div> + <div class="col-sm-6"> + <md2-select + style="margin-top:10px;" + id="type" + name="type" + placeholder="{{lang.type}}" + [(ngModel)]="type" + required + [disabled]="!creationMode" + #selectType> + <md2-option value="string" >{{lang.string}}</md2-option> + <md2-option value="int">{{lang.integer}}</md2-option> + <md2-option value="date">{{lang.date}}</md2-option> + </md2-select> </div> - </div> - <div class="form-group"> - <div class="col-sm-12"> - <div class="input-group"> - <span class="input-group-addon"><i aria-hidden="true" class="fa fa-code" title="{{this.lang.value}}"></i><sup class="mandatory" title="champ requis">*</sup></span> - <input *ngIf = "type == 'string'" [(ngModel)]="parameter.param_value_string" class="form-control" name="paramValue" id="paramValue" title="{{this.lang.value}}" type="text" placeholder="{{this.lang.value}}" required> - <input *ngIf = "type == 'int'" [(ngModel)]="parameter.param_value_int" class="form-control" name="paramValue" id="paramValue" title="{{this.lang.value}}" type="number" placeholder="{{this.lang.value}}" required> - <input *ngIf = "type == 'date'" [(ngModel)]="parameter.param_value_date" class="form-control" name="paramValue" id="paramValue" title="{{this.lang.value}}" type="date" placeholder="{{this.lang.value}}" required> - </div> + <div class="col-sm-6"> + + <md-input-container *ngIf = "type == 'string'"> + <input mdInput [(ngModel)]="parameter.param_value_string" name="paramValue" id="paramValue" title="{{lang.value}}" type="text" placeholder="{{lang.value}}"> + </md-input-container> + <md-input-container *ngIf = "type == 'int'"> + <input mdInput [(ngModel)]="parameter.param_value_int" name="paramValue" id="paramValue" title="{{lang.value}}" type="text" placeholder="{{lang.value}}"> + </md-input-container> + <md2-datepicker *ngIf = "type == 'date'" + name="paramValue" + placeholder="{{this.lang.value}}" + [(ngModel)]="parameter.param_value_date" + mode="auto" + format="dd-MM-y" + #minDateControl="ngModel" + isOpenOnFocus> + </md2-datepicker> </div> </div> <div class="col-sm-12" style="text-align:center;"> diff --git a/apps/maarch_entreprise/Views/parameters-administration.component.html b/apps/maarch_entreprise/Views/parameters-administration.component.html index 39989cb7db27feeacae2405149cd687242fabf82..e8fbed04d3b7e386757fb53f8642cf7ae4a882f7 100755 --- a/apps/maarch_entreprise/Views/parameters-administration.component.html +++ b/apps/maarch_entreprise/Views/parameters-administration.component.html @@ -1,42 +1,41 @@ -<div id="resultInfo" class="fade" style="display:none;"> - {{resultInfo}} +<div class="page-header"> + <h1>{{lang.administration}} {{lang.parameters}} <small>{{data.length}} {{lang.parameters}}</small></h1> </div> <div *ngIf="loading"> - <i class="fa fa-spinner fa-spin fa-5x" style="margin-left: 50%;margin-top: 16%;font-size: 8em"></i> + <md-spinner style="margin:auto;"></md-spinner> </div> <div *ngIf="!loading" class="container-fluid"> - <h1 style="margin-top: 0"><i class="fa fa-wrench fa-2x"></i> {{lang.admin}} {{lang.parameters}} : {{parametersList.length}} {{lang.parameter}}(s)</h1> - <nav class="navbar navbar-default" style="font-size:17px !important;" id="toolBox"> - <div class="container-fluid"> - <div class="navbar-header"> - <a class="navbar-brand" routerLink="/administration" style="cursor: pointer"> - <i class="fa fa-arrow-circle-left" title="{{lang.back}}"></i> - </a> - </div> - <div class="collapse navbar-collapse" id="bs-example-navbar-collapse-1"> - <ul class="nav navbar-nav navbar-right"> - <li style="cursor: pointer" routerLink="/administration/parameters/new"> - <a title="{{lang.new_parameter}}"><i class="fa fa-wrench"></i><sup><i class="fa fa-plus"></i></sup></a> - </li> - </ul> - </div> - </div> - </nav> <div class="col-md-12"> - <table id ="paramsTable" class="display" style="display:none;"> + <table id ="paramsTable" class="table table-hover table-condensed" [md2Data]="data | dataPipe : 'id' : search" #md2="md2DataTable" [sortBy]='id' [rowsPerPage]="10"> <thead> <tr> - <th style="width:10%;"><span>{{lang.identifier}}</span></th> - <th style="width:30%;"><span>{{lang.description}}</span></th> - <th style="width:30%;"><span>{{lang.value}}</span></th> + <td colspan="5"> + <md2-pagination></md2-pagination> + </td> + <td style="text-align:right;"> + <md-input-container> + <input mdInput placeholder="{{lang.filterBy}} : {{lang.id}}" class="searchTable" [(ngModel)]="search" /> + </md-input-container> + + <a class="text-primary" style="cursor: pointer" routerLink="/administration/parameters/new" title="{{lang.addUser}}"><i class="fa fa-wrench fa-2x"></i><sup><i class="fa fa-plus"></i></sup></a> + </td> + </tr> + <tr> + <th md2SortBy="id"style="width:10%;"><span>{{lang.id}}</span></th> + <th md2SortBy="description"style="width:30%;"><span>{{lang.desc}}</span></th> + <th md2SortBy="param_value_string"style="width:10%;"><span>{{lang.value}}</span></th> + <th md2SortBy="param_value_int"style="width:10%;"><span>{{lang.value}}</span></th> + <th md2SortBy="param_value_date"style="width:10%;"><span>{{lang.value}}</span></th> <th style="width:30%;"><span> </span></th> </tr> </thead> <tbody> - <tr *ngFor="let parameter of parametersList" id="{{parameter.id}}"> - <td style="width:10%;"> {{parameter.id}} </td> - <td style="width:30%;"> {{parameter.description}} </td> - <td style="width:30%;"> {{parameter.param_value_string || parameter.param_value_int || parameter.param_value_date}} </td> + <tr *ngFor="let parameter of md2.data"> + <td style="width:10%;vertical-align:middle;">{{parameter.id}}</td> + <td style="width:30%;vertical-align:middle;">{{parameter.description}}</td> + <td style="width:10%;vertical-align:middle;">{{parameter.param_value_string}}</td> + <td style="width:10%;vertical-align:middle;">{{parameter.param_value_int}}</td> + <td style="width:10%;vertical-align:middle;">{{parameter.param_value_date}}</td> <td style="text-align:right;width:30%;"> <div class="btn-group" role="group"> <button routerLink="/administration/parameters/{{parameter.id}}" type="button" class="btn btn-default" title="{{lang.modify}}"> diff --git a/apps/maarch_entreprise/Views/status-administration.component.html b/apps/maarch_entreprise/Views/status-administration.component.html index d3b4862a0884fc159b0bbebf53e61f2d52331c57..74150cad34a00fb2c5b25ee5c1447eb57eefa0fc 100755 --- a/apps/maarch_entreprise/Views/status-administration.component.html +++ b/apps/maarch_entreprise/Views/status-administration.component.html @@ -1,104 +1,87 @@ +<div class="page-header"> + <h1 *ngIf="!creationMode">{{lang.statusModification}} <small>{{status.id}}</small></h1> + <h1 *ngIf="creationMode">{{lang.statusCreation}} <small>{{status.id}}</small></h1> +</div> <div *ngIf="loading"> - <i class="fa fa-spinner fa-spin fa-5x" style="margin-left: 50%;margin-top: 16%;font-size: 8em"></i> + <md-spinner style="margin:auto;"></md-spinner> </div> -<nav class="navbar navbar-default" style="font-size:17px !important;" id="toolBox"> - <div class="container-fluid"> - <div class="navbar-header"> - <a class="navbar-brand" routerLink="/administration/status" style="cursor: pointer"> - <i class="fa fa-arrow-circle-left" title="{{lang.back}}"></i> - </a> - </div> - <div class="collapse navbar-collapse" id="bs-example-navbar-collapse-1"> - <ul class="nav navbar-nav navbar-right"> - - </ul> - </div> - </div> -</nav> -<h1 style="margin-top: 0"><i class="fa fa-check-circle fa-2x"></i> {{pageTitle}}</h1> -<div class="container-fluid" style="border-left:solid 1px white;border-right:solid 1px white;background-color: #CEE9F1;border-top: solid 2px #FDD16C;border-bottom: solid 2px #FDD16C;padding:10px;"> -<div class="col-md-6 col-md-offset-3"> - <form class="form-horizontal" (ngSubmit)="submitStatus()" #statusFormUp="ngForm"> - <div class="form-group"> - <div class="col-sm-12"> - <div class="input-group"> - <span class="input-group-addon"><i aria-hidden="true" class="fa fa-hashtag" title="{{lang.identifier}}"></i><sup class="mandatory" title="champ requis"><i class="fa fa-asterisk" aria-hidden="true"></i></sup></span> - <input [(ngModel)]="status.id" class="form-control" [disabled]="mode == 'update'" maxlength="10" name="id" id="id" title="{{lang.identifier}}" type="text" required> +<div *ngIf="!loading" class="container-fluid"> + <div class="col-md-6 col-md-offset-3"> + <form class="form-horizontal" (ngSubmit)="submitStatus()" #statusFormUp="ngForm"> + <div class="form-group"> + <div class="col-sm-12"> + <md-input-container> + <input mdInput [(ngModel)]="status.id" [disabled]="mode == 'update'" maxlength="10" name="id" id="id" title="{{lang.id}}" placeholder="{{lang.id}}" type="text" required> + </md-input-container> </div> </div> - </div> - <div class="form-group"> - <div class="col-sm-12"> - <div class="input-group"> - <span class="input-group-addon"><i aria-hidden="true" class="fa fa-tag" title="{{lang.description}}"></i><sup class="mandatory" title="champ requis"><i class="fa fa-asterisk" aria-hidden="true"></i></sup></span> - <input class="form-control" name="label_status" id="label_status" maxlength="50" [(ngModel)]="status.label_status" title="{{lang.description}}" type="text" required> + <div class="form-group"> + <div class="col-sm-12"> + <md-input-container> + <input mdInput name="label_status" id="label_status" maxlength="50" [(ngModel)]="status.label_status" title="{{lang.desc}}" placeholder="{{lang.desc}}" type="text" required> + </md-input-container> </div> </div> - </div> - <div class="form-group"> - <div class="col-sm-4"> - <div class="input-group"> - <span class="input-group-btn"> - <button data-tooltip-content="#infoSearchableTooltip" class="btn btn-default help" type="button"><i class="fa fa-question-circle"></i></button> - </span> - <label class="form-control" for="can_be_searched">{{lang.can_be_searched}}</label> - <span class="input-group-addon"> - <input [(ngModel)]="status.can_be_searched" name="can_be_searched" id="can_be_searched" type="checkbox"> - </span> + <div class="form-group"> + <div class="panel panel-default"> + <div class="panel-body"> + <div class="col-sm-4" style="white-space:nowrap;"> + <md-slide-toggle [(ngModel)]="status.can_be_searched" id="can_be_search" name="can_be_search" color="primary" [checked]="status.can_be_searched == true"> + {{lang.canBeSearched}} + </md-slide-toggle> + <sup> + <i class="fa fa-question-circle" tooltip="Si <b>coché</b>,<br/>le statut <b>{{status.id}}</b> vous <b>proposé</b> pour le critère de recherche STATUS de la recherche avancée de documents."></i> + </sup> + </div> + <div class="col-sm-4" style="white-space:nowrap;"> + <md-slide-toggle [(ngModel)]="status.can_be_modified" id="can_be_modified" name="can_be_modified" color="primary" [checked]="status.can_be_modified == true"> + {{lang.canBeModified}} + </md-slide-toggle> + <sup> + <i class="fa fa-question-circle" tooltip="Si <b>coché</b>,<br/>vous pourrez <b>modifier</b> les meta-données des documents ayant le statut <b>{{status.id}}</b>."></i> + </sup> + </div> + <div class="col-sm-4" style="white-space:nowrap;"> + <md-slide-toggle [(ngModel)]="status.is_folder_status" id="is_folder_status" name="is_folder_status" color="primary" [checked]="status.is_folder_status == true"> + {{lang.isFolderStatus}} + </md-slide-toggle> + <sup> + <i class="fa fa-question-circle" tooltip="Si <b>coché</b>,<br/>le statut <b>{{status.id}}</b> pourra être utilisé pour des <b>bannettes de dossiers</b>."></i> + </sup> + </div> + </div> </div> </div> - <div class="col-sm-4"> - <div class="input-group"> - <span class="input-group-btn"> - <button data-tooltip-content="#infoCanBeModifiedTooltip" class="btn btn-default help" type="button"><i class="fa fa-question-circle"></i></button> - </span> - <label class="form-control" for="can_be_modified">{{lang.can_be_modified}}</label> - <span class="input-group-addon"> - <input [(ngModel)]="status.can_be_modified" type="checkbox" name="can_be_modified" id="can_be_modified"> - </span> + <div class="form-group"> + <div class="col-sm-1"> + <i class="fm {{status.img_filename}} fm-2x text-primary"></i> </div> - </div> - <div class="col-sm-4"> - <div class="input-group"> - <span class="input-group-btn"> - <button data-tooltip-content="#infoIsFolderStatusTooltip" class="btn btn-default help" type="button"><i class="fa fa-question-circle"></i></button> - </span> - <label class="form-control" for="is_folder_status">{{lang.is_folder_status}}</label> - <span class="input-group-addon"> - <input [(ngModel)]="status.is_folder_status" type="checkbox" name="is_folder_status" id="is_folder_status"> - </span> + <div class="col-sm-11"> + <md2-select + id="status" + name="status" + placeholder="{{lang.imgRelated}}" + [(ngModel)]="status.img_filename" + required + #searchStatusIcon="ngModel"> + <md2-select-header> + <md-input-container> + <input mdInput name="search" + type="text" + placeholder="Filtre" + [(ngModel)]="_search" + autocomplete="off" + (focusout)="clearSearch()"/> + </md-input-container> + </md2-select-header> + <md2-option *ngFor="let image of statusImages | dataPipe : 'image_name' : _search" [value]="image.image_name"><i [ngClass]="[image.image_name.indexOf('fm') == 0 ? 'fm' : 'fa']" class="{{image.image_name}} fa-2x"></i> {{image.image_name}}</md2-option> + </md2-select> </div> </div> - </div> - <div id="statusIconList" class="form-group panel panel-default"> - <div class="col-sm-12 panel-heading" style="font-size: 14px;text-align:center;"> - <i class="fa fa-picture-o" aria-hidden="true"></i> {{lang.img_related}} - </div> - <div class="col-sm-12 panel-body"> - <button *ngFor="let image of statusImages" type="button" [ngClass]="[status.img_filename==image.image_name ? 'btn-primary' : 'btn-default']" class="btn btn-group-lg" (click)="selectImage(image.image_name)"> - <i id="img_0" [ngClass]="[image.image_name.indexOf('fm') == 0 ? 'fm' : 'fa']" class="{{image.image_name}}"></i> - </button> + <div class="col-sm-12 panel-body" style="text-align:center;"> + <button class="btn btn-default" type="submit" [disabled]="!statusFormUp.form.valid">{{lang.validate}}</button> + <button class="btn btn-default" routerLink='/administration/status'>{{lang.cancel}}</button> </div> - </div> - <div class="col-sm-12 panel-body" style="text-align:center;"> - <button class="btn btn-default" type="submit" [disabled]="!statusFormUp.form.valid">{{lang.validate}}</button> - <button class="btn btn-default" routerLink='/administration/status'>{{lang.cancel}}</button> - </div> - </form> -</div> -</div> - -<div class="tooltip_templates" style="display: none"> - <span id="infoSearchableTooltip"> - Si <b>coché</b>,<br/> - le statut <b>{{status.id}}</b> vous <b>proposé</b> pour le critère de recherche STATUS de la recherche avancée de documents. - </span> - <span id="infoCanBeModifiedTooltip"> - Si <b>coché</b>,<br/> - vous pourrez <b>modifier</b> les meta-données des documents ayant le statut <b>{{status.id}}</b>. - </span> - <span id="infoIsFolderStatusTooltip"> - Si <b>coché</b>,<br/> - le statut <b>{{status.id}}</b> pourra être utilisé pour des <b>bannettes de dossiers</b>. - </span> + </form> + </div> </div> \ No newline at end of file diff --git a/apps/maarch_entreprise/Views/statuses-administration.component.html b/apps/maarch_entreprise/Views/statuses-administration.component.html index 5282ffbf6e8736d616b346ce3ad61809c9bfa2b0..f7ebf58cb076f65906f57f879e7563cd37ea752e 100755 --- a/apps/maarch_entreprise/Views/statuses-administration.component.html +++ b/apps/maarch_entreprise/Views/statuses-administration.component.html @@ -1,49 +1,47 @@ + +<div class="page-header"> + <h1>{{lang.administration}} {{lang.statuses}} <small>{{data.length}} {{lang.statuses}}</small></h1> +</div> <div *ngIf="loading"> - <i class="fa fa-spinner fa-spin fa-5x" style="margin-left: 50%;margin-top: 16%;font-size: 8em"></i> + <md-spinner style="margin:auto;"></md-spinner> </div> <div *ngIf="!loading" class="container-fluid"> - <nav class="navbar navbar-default" style="font-size:17px !important;" id="toolBox"> - <div class="container-fluid"> - <div class="navbar-header"> - <a class="navbar-brand" routerLink="/administration" style="cursor: pointer"> - <i class="fa fa-arrow-circle-left" title="{{lang.back}}"></i> - </a> - </div> - <div class="collapse navbar-collapse" id="bs-example-navbar-collapse-1"> - <ul class="nav navbar-nav navbar-right"> - <li style="cursor: pointer" routerLink="/administration/status/new"> - <a title="{{lang.newStatus}}"><i class="fa fa-check-circle"></i><sup><i class="fa fa-plus"></i></sup></a> - </li> - </ul> - </div> - </div> - </nav> - <h1 style="margin-top: 0"><i class="fa fa-check-circle fa-2x"></i> {{lang.statusListTitle}} : {{nbStatus}} {{lang.status}}(s)</h1> - - <div class="col-md-12" style="margin-top: 15px"> - <table id="statusTable" class="display"> + <div class="col-md-12"> + <table id="statusTable" class="table table-hover table-condensed" [md2Data]="data | dataPipe : 'label_status' : search" #md2="md2DataTable" [sortBy]='label_status' [rowsPerPage]="10"> <thead> <tr> - <th style="width:50px;"><span>{{lang.img_related}}</span></th> - <th><span>{{lang.identifier}}</span></th> - <th><span>{{lang.description}}</span></th> - <th><span> </span></th> + <td colspan="3"> + <md2-pagination></md2-pagination> + </td> + <td style="text-align:right;"> + <md-input-container> + <input mdInput placeholder="{{lang.filterBy}} : {{lang.desc}}" class="searchTable" [(ngModel)]="search" /> + </md-input-container> + + <a class="text-primary" style="cursor: pointer" routerLink="/administration/status/new" title="{{lang.addStatus}}"><i class="fa fa-check-circle fa-2x"></i><sup><i class="fa fa-plus"></i></sup></a> + </td> + </tr> + <tr> + <th md2SortBy="id" style="width:50px;"><span>{{lang.imgRelated}}</span></th> + <th md2SortBy="img_filename"><span>{{lang.id}}</span></th> + <th md2SortBy="label_status"><span>{{lang.desc}}</span></th> + <th> </th> </tr> </thead> <tbody> - <tr *ngFor="let status of statusList" id="{{status.id}}"> - <td style="text-align:center;"> - <i class="fm {{status.img_filename}} fm-2x" *ngIf="status.img_filename.indexOf('fm') == 0"></i> - <i class="fa {{status.img_filename}} fa-2x" *ngIf="status.img_filename.indexOf('fa') == 0"></i> + <tr *ngFor="let status of md2.data"> + <td style="text-align:center;vertical-align:middle;"> + <i class="fm {{status.img_filename}} fm-2x text-primary" *ngIf="status.img_filename.indexOf('fm') == 0"></i> + <i class="fa {{status.img_filename}} fa-2x text-primary" *ngIf="status.img_filename.indexOf('fa') == 0"></i> </td> - <td>{{status.id}}</td> - <td>{{status.label_status}}</td> - <td style="text-align:right;"> + <td style="vertical-align:middle;">{{status.id}}</td> + <td style="vertical-align:middle;">{{status.label_status}}</td> + <td style="text-align:right;vertical-align:middle;"> <div class="btn-group" role="group" aria-label="..."> <button routerLink="/administration/status/{{status.identifier}}" type="button" class="btn btn-default" title="{{lang.edit}}"> <a><i style="cursor:pointer" class="fa fa-edit"></i></a> </button> - <button type="button" class="btn btn-default" title="{{lang.delete}}" (click)="deleteStatus(status.id, status.identifier)"> + <button type="button" class="btn btn-default" title="{{lang.delete}}" (click)="deleteStatus(status)"> <a><i style="cursor:pointer;color: #D9534F" class="fa fa-trash"></i></a> </button> </div> diff --git a/apps/maarch_entreprise/Views/user-administration.component.html b/apps/maarch_entreprise/Views/user-administration.component.html index c0cc2ee8386d2e1aaeb50b6ddfa46d1832ea68bd..5fe0c8c7ba1751d81fc84c20b015a47e51785369 100755 --- a/apps/maarch_entreprise/Views/user-administration.component.html +++ b/apps/maarch_entreprise/Views/user-administration.component.html @@ -1,269 +1,179 @@ +<div class="page-header"> + <h1 *ngIf="!creationMode">{{lang.userModification}} <small>{{user.lastname}} {{user.firstname}}</small></h1> + <h1 *ngIf="creationMode">{{lang.userCreation}} <small>{{user.lastname}} {{user.firstname}}</small></h1> +</div> <div *ngIf="loading"> - <i class="fa fa-spinner fa-spin fa-5x" style="margin-left: 50%;margin-top: 16%;font-size: 8em"></i> + <md-spinner style="margin:auto;"></md-spinner> </div> <div *ngIf="!loading" class="container-fluid"> - <h1 *ngIf="userCreation" style="margin-top: 0"> - <i class="fa fa-user fa-2x"></i> {{lang.userCreation}} {{user.userId}} - </h1> - <h1 *ngIf="!userCreation" style="margin-top: 0"> - <i class="fa fa-user fa-2x"></i> {{lang.userModification}} : {{userId}} - <sup> - <span *ngIf="user.status == 'OK' && user.enabled == 'Y'" class="label label-primary">{{lang.active}}</span> - <span *ngIf="user.enabled == 'N'" class="label label-danger">{{lang.inactive}}</span> - <span *ngIf="user.status == 'ABS'" class="label label-warning">{{lang.abs}}</span> - </sup> - </h1> - <nav class="navbar navbar-default" id="toolBox"> - <div class="container-fluid"> - <div class="navbar-header"> - <a routerLink="/administration/users" class="navbar-brand" style="cursor: pointer"> - <i class="fa fa-arrow-circle-left" title="{{lang.back}}"></i> - </a> - </div> - <div *ngIf="!userCreation" class="collapse navbar-collapse" id="bs-example-navbar-collapse-1"> - <ul class="nav navbar-nav navbar-right userAdministrationClickable"> - <li> - <a (click)="resetPassword()"><i class="fa fa-key"></i> {{lang.reinitPassword}}</a> - </li> - <li *ngIf="user.status == 'ABS'"> - <a (click)="deactivateAbsence()"><i class="fa fa-user"></i> {{lang.deactivateAbs}}</a> - </li> - <li *ngIf="user.status == 'OK'"> - <a data-toggle="modal" data-target="#manageAbs"><i class="fa fa-user-times"></i> {{lang.manageAbsences}}</a> - </li> - <li> - <a data-toggle="modal" data-target="#manageSign"><i class="fa fa-vcard-o"></i> {{lang.manageSignatures}}</a> - </li> - </ul> - </div> - </div> - </nav> - <div class="row row-eq-height"> - <div class="col-md-4" [ngClass]="{'col-md-offset-4': userCreation}" style="border-left:solid 1px white;border-right:solid 1px white;background-color: #CEE9F1;border-top: solid 2px #FDD16C;border-bottom: solid 2px #FDD16C;padding:10px;"> - <h2>{{lang.informations}}</h2> - <form class="form-horizontal" (ngSubmit)="onSubmit()" #profileForm="ngForm"> - <div class="form-group"> - <div class="col-sm-12"> - <div class="input-group"> - <span class="input-group-addon"><i class="fa fa-user" aria-hidden="true"></i></span> - <input *ngIf="userCreation" type="text" class="form-control" name="user_id" [(ngModel)]="user.userId" placeholder="{{lang.id}}" pattern="^[\w.@-]*$" required> - <input *ngIf="!userCreation" type="text" class="form-control" title="{{lang.id}}" value="{{user.user_id}}" disabled> - </div> + <div class="container-fluid"> + <md-tab-group (selectChange)="initService()"> + <md-tab label="Informations"> + <div *ngIf="user.status == 'ABS'" class="text-warning" style="position: absolute;opacity: 0.1;font-size: 120px;transform: rotate(324deg);-webkit-transform: rotate(324deg);margin-left: 35%;margin-top: 90px;">{{user.status}}</div> + <div class="col-md-6 col-md-offset-3"> + <div class="example-sidenav-content"> + <form class="form-horizontal" (ngSubmit)="onSubmit()" #profileForm="ngForm"> + <div class="form-group"> + <div class="col-sm-12"> + <div class="pull-left image"> + <img src="img/maarch_box.png" class="img-circle avatar" alt="user profile image"> + </div> + <div class="input-group"> + <!--<span class="input-group-addon"><i class="fa fa-user" aria-hidden="true"></i></span>--> + <md-input-container> + <input mdInput *ngIf="creationMode" type="text" title="{{lang.id}}" name="user_id" [(ngModel)]="user.userId" placeholder="{{lang.id}}" + pattern="^[\w.@-]*$" required> + + <input mdInput *ngIf="!creationMode" type="text" title="{{lang.id}}" value="{{user.user_id}}" placeholder="{{lang.id}}" disabled> + </md-input-container> + </div> + </div> + </div> + <div class="form-group"> + <div class="col-sm-5" style="font-weight:bold;"> + <md-input-container> + <input mdInput type="text" id="lastname" name="lastname" title="{{lang.lastname}}" placeholder="{{lang.lastname}}" [(ngModel)]="user.lastname" + required> + </md-input-container> + </div> + <div class="col-sm-5" style="font-weight:bold;"> + <md-input-container> + <input mdInput type="text" id="firstname" name="firstname" title="{{lang.firstname}}" placeholder="{{lang.firstname}}" [(ngModel)]="user.firstname" + required> + </md-input-container> + </div> + <div class="col-sm-2" style="font-style:italic;"> + <md-input-container> + <input mdInput type="text" id="initials" name="initials" title="{{lang.initials}}" placeholder="{{lang.initials}}" [(ngModel)]="user.initials"> + </md-input-container> + </div> + </div> + <div class="form-group"> + <div class="col-sm-12"> + <md-input-container> + <input mdInput type="tel" id="phone" name="phone" title="{{lang.phoneNumber}}" placeholder="{{lang.phoneNumber}}" [(ngModel)]="user.phone" + pattern="^(?:0|\+\d\d?\d?\s?)[1-9]([\.\-\s]?\d\d){4}([\.\-\s]?\d?\d?)$"> + </md-input-container> + </div> + </div> + <div class="form-group"> + <div class="col-sm-12"> + <md-input-container> + <input mdInput type="email" id="mail" name="mail" title="{{lang.email}}" placeholder="{{lang.email}}" [(ngModel)]="user.mail" + pattern="[^@\s]+@[^@\s]+"> + </md-input-container> + </div> + </div> + <div class="form-group"> + <div class="col-sm-12"> + <md-input-container> + <input mdInput type="text" id="fingerprint" name="fingerprint" title="{{lang.fingerprint}}" placeholder="{{lang.fingerprint}}" + [(ngModel)]="user.thumbprint"> + </md-input-container> + </div> + </div> + <div class="form-group"> + <div style="text-align:center;"> + <button *ngIf="creationMode" type="submit" class="btn btn-success" [disabled]="!profileForm.form.valid"><i class="fa fa-plus"></i> {{lang.save}}</button> + <button *ngIf="!creationMode" type="submit" class="btn btn-success" [disabled]="!profileForm.form.valid"><i class="fa fa-save"></i> {{lang.update}}</button> + <button *ngIf="user.status != 'ABS' && !creationMode" type="button" (click)="activateAbsence()" class="btn btn-warning"><i class="fa fa-plane"></i> {{lang.activateAbsence}}</button> + <button *ngIf="user.status == 'ABS' && !creationMode" type="button" (click)="desactivateAbsence()" class="btn btn-success"><i class="fa fa-check"></i> {{lang.desactivateAbsence}}</button> + <button type="button" *ngIf="!creationMode" (click)="resetPassword(user)" class="btn btn-default"><i class="fa fa-key"></i> {{lang.reinitPassword}}</button> + </div> + </div> + </form> </div> </div> - <div class="form-group"> - <div class="col-sm-5" style="font-weight:bold;"> - <input type="text" class="form-control" id="lastname" name="lastname" title="{{lang.lastname}}" placeholder="{{lang.lastname}}" [(ngModel)]="user.lastname" required> - </div> - <div class="col-sm-5" style="font-weight:bold;"> - <input type="text" class="form-control" id="firstname" name="firstname" title="{{lang.firstname}}" placeholder="{{lang.firstname}}" [(ngModel)]="user.firstname" required> - </div> - <div class="col-sm-2" style="font-style:italic;"> - <input type="text" class="form-control" id="initials" name="initials" title="{{lang.initials}}" placeholder="{{lang.initials}}" [(ngModel)]="user.initials"> + </md-tab> + <md-tab *ngIf="!creationMode" label="Groupe(s)"> + <div class="col-md-6"> + <div class="groupList"> + <ul class="list-group col-md-12"> + <li class="list-group-item" *ngFor="let group of user.allGroups"> + <md-slide-toggle id="{{group.group_id}}" color="primary" [checked]="group.disabled == true" (change)="toggleGroup(group)">{{group.group_desc}}</md-slide-toggle> + </li> + </ul> </div> </div> - <div class="form-group"> - <div class="col-sm-12"> - <div class="input-group"> - <span class="input-group-addon"><i class="fa fa-phone" aria-hidden="true"></i></span> - <input type="tel" class="form-control" id="phone" name="phone" title="{{lang.phoneNumber}}" placeholder="{{lang.phoneNumber}}" [(ngModel)]="user.phone" pattern="^(?:0|\+\d\d?\d?\s?)[1-9]([\.\-\s]?\d\d){4}([\.\-\s]?\d?\d?)$"> + <div class="col-md-4 col-md-offset-1"> + <div class="panel" *ngFor="let userGroup of user.groups" [ngClass]="[userGroup.primary_group == 'Y' ? 'panel-primary' : 'panel-default']"> + <div class="panel-heading"> + {{userGroup.group_desc}} <i *ngIf="userGroup.primary_group != 'Y'" class="fa fa-asterisk" aria-hidden="true"></i> </div> - </div> - </div> - <div class="form-group"> - <div class="col-sm-12"> - <div class="input-group"> - <span class="input-group-addon"><i class="fa fa-envelope-o" aria-hidden="true"></i></span> - <input type="email" class="form-control" id="mail" name="mail" title="{{lang.email}}" placeholder="{{lang.email}}" [(ngModel)]="user.mail" pattern="[^@\s]+@[^@\s]+"> + <div class="panel-body"> + <md-input-container> + <input mdInput type="text" id="role" name="role" title="{{lang.role}}" placeholder="{{lang.role}}" [(ngModel)]="userGroup.role" + (focusout)="updateGroup(userGroup)"> + </md-input-container> + <div class="col-md-12"> + <ul class="list-unstyled"> + <li *ngFor="let basket of user.baskets; let i = index"> + <span *ngIf="basket.group_id == userGroup.group_id"> + <md-slide-toggle [(ngModel)]="basket.enabled" color="primary">{{basket.basket_name}} <small class="text-danger" style="font-style:italic;" *ngIf="basket.userToDisplay != '' && basket.enabled">(Redirigé à {{basket.userToDisplay}})</small></md-slide-toggle> + <i (click)="toogleRedirect(basket)" *ngIf="basket.userToDisplay == '' && basket.enabled" mdTooltip="Rediriger la banette à une personne lors de l'activation de l'absence" mdTooltipPosition="above" + class="fa fa-share-square text-primary" style="cursor:pointer;"></i> + <sup><i style="cursor:pointer;" *ngIf="basket.userToDisplay != '' && basket.enabled" mdTooltip="Supprimer la redirection" class="fa fa-times text-danger" aria-hidden="true" (click)="delBasketRedirection(i)"></i></sup> + <div *ngIf="basket.userToDisplay == '' && basket.enabled" id="redirectUser_{{basket.group_id}}_{{basket.basket_id}}" style="display:none;"> + <md2-autocomplete + [items]="userList" + item-text="user_id" + item-value="user_id" + placeholder="utilisateur de redirection" + [(ngModel)]="basket.userToDisplay" + required + (change)="addBasketRedirection(i,basket)"> + </md2-autocomplete> + </div> + </span> + </li> + </ul> + </div> </div> - - </div> - </div> - <div class="form-group"> - <div class="col-sm-12"> - <div class="input-group"> - <span class="input-group-addon"><i class="fa fa-paw" aria-hidden="true"></i></span> - <input type="text" class="form-control" id="fingerprint" name="fingerprint" title="{{lang.fingerprint}}" placeholder="{{lang.fingerprint}}" [(ngModel)]="user.thumbprint"> + <div class="panel-footer"> + <md-input-container> + <input value="{{userGroup.maarch_comment}}" mdInput type="text" title="{{lang.perimeter}}" placeholder="Ressource documentaire" + disabled> + </md-input-container> </div> </div> </div> - <div class="form-group"> - <div style="text-align:center;"> - <button type="submit" class="btn btn-success" [disabled]="!profileForm.form.valid">{{lang.save}}</button> - </div> - </div> - </form> - </div> - <div *ngIf="!userCreation" class="col-md-3 col-md-offset-1" style="border-left:solid 1px white;border-right:solid 1px white;background-color: #CEE9F1;border-top: solid 2px #FDD16C;border-bottom: solid 2px #FDD16C;padding:10px;"> - <h2>{{lang.groups}} <i class="fa fa-plus pull-right" data-toggle="modal" data-target="#addGroupModal" style="cursor:pointer;" aria-hidden="true" title="Ajouter un groupe"></i></h2> - <div *ngFor="let group of user.groups" class="col-sm-12 form-group"> - <div class="input-group"> - <div class="input-group-btn"> - <button type="button" style="color:white;" class="btn btn-default dropdown-toggle label-primary" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">{{group.group_desc}} <span class="caret"></span></button> - <ul class="dropdown-menu userAdministrationClickable"> - <li><a (click)="updateGroup(group)">{{lang.save}}</a></li> - <li role="separator" class="divider"></li> - <li><a (click)="deleteGroup(group)">{{lang.delete}}</a></li> - </ul> - </div> - <input type="text" class="form-control" aria-describedby="group_desc" placeholder="{{lang.role}}" [(ngModel)]="group.role"> - </div> - </div> - <div *ngIf="user.groups.length == 0" class="col-sm-12 form-group"> - L'utilisateur n'appartient à aucun groupe. - </div> - </div> - <div *ngIf="!userCreation" class="col-md-3 col-md-offset-1" style="border-left:solid 1px white;border-right:solid 1px white;background-color: #CEE9F1;border-top: solid 2px #FDD16C;border-bottom: solid 2px #FDD16C;padding:10px;"> - <h2>{{lang.entities}} <i class="fa fa-plus pull-right" data-toggle="modal" data-target="#addEntityModal" style="cursor:pointer;" aria-hidden="true" title="Ajouter une entité"></i></h2> - <div *ngFor="let entity of user.entities" class="col-sm-12 form-group"> - <div class="input-group"> - <div class="input-group-btn"> - <button *ngIf="entity.primary_entity == 'Y'" type="button" style="color:white;" class="btn btn-default dropdown-toggle label-primary" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false" [title]="entity.entity_label">{{entity.entity_id}} <span class="caret"></span></button> - <button *ngIf="entity.primary_entity == 'N'" type="button" style="background-color:#eee;" class="btn btn-default dropdown-toggle label-default" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false" [title]="entity.entity_label">{{entity.entity_id}} <span class="caret"></span></button> - <ul class="dropdown-menu userAdministrationClickable"> - <li *ngIf="entity.primary_entity == 'N'"><a (click)="updatePrimaryEntity(entity)">Passer en entité primaire</a></li> - <li><a (click)="updateEntity(entity)">{{lang.save}}</a></li> - <li role="separator" class="divider"></li> - <li><a (click)="deleteEntity(entity)">{{lang.delete}}</a></li> - </ul> - </div> - <input type="text" class="form-control" aria-describedby="group_desc" placeholder="{{lang.role}}" [(ngModel)]="entity.user_role"> + </md-tab> + <md-tab *ngIf="!creationMode" label="Entité(s)"> + <div class="col-md-6"> + <md-input-container> + <input mdInput id="jstree_search" type="text" placeholder="Rechercher une entité"> + </md-input-container> + <div id="jstree"></div> </div> - </div> - <div *ngIf="user.entities.length == 0" class="col-sm-12 form-group"> - L'utilisateur n'appartient à aucune entité. - </div> - </div> - </div> -</div> - -<!-- ADD GROUP --> -<div class="modal fade" id="addGroupModal" tabindex="-1" role="dialog" aria-labelledby="addGroupModalLabel"> - <div class="modal-dialog" role="document"> - <div class="modal-content"> - <div class="modal-header"> - <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">×</span></button> - <h4 class="modal-title" id="addGroupModalLabel">Ajouter un groupe</h4> - </div> - <div class="modal-body"> - <form class="form-horizontal"> - <div class="form-group"> - <div class="col-sm-6"> - <select id="groupsSelect" class="form-control"> - <option>{{lang.chooseGroup}}</option> - <option *ngFor="let group of user.allGroups" [disabled]="group.disabled">{{group.group_desc}}</option> - </select> + <div class="col-md-4 col-md-offset-1"> + <div class="panel" *ngFor="let userEntity of user.entities" [ngClass]="[userEntity.primary_entity == 'Y' ? 'panel-primary' : 'panel-default']"> + <div class="panel-heading"> + {{userEntity.entity_label}} <i mdTooltip="Passer en entité primaire" *ngIf="userEntity.primary_entity != 'Y'" + (click)="updatePrimaryEntity(userEntity)" class="fa fa-asterisk text-primary pull-right" style="cursor:pointer;"></i> </div> - <div class="col-sm-6"> - <input id="groupRole" class="form-control" placeholder="{{lang.role}}" type="text"> + <div class="panel-body"> + <md-input-container> + <input mdInput type="text" id="role" name="role" title="{{lang.role}}" placeholder="{{lang.role}}" [(ngModel)]="userEntity.user_role" + (focusout)="updateEntity(userEntity)"> + </md-input-container> </div> </div> - </form> - </div> - <div class="modal-footer"> - <button (click)="addGroup()" type="button" class="btn btn-success">{{lang.validate}}</button> - </div> - </div> - </div> -</div> - -<!-- ADD ENTITY --> -<div class="modal fade" id="addEntityModal" tabindex="-1" role="dialog" aria-labelledby="addEntityModalLabel"> - <div class="modal-dialog" role="document"> - <div class="modal-content"> - <div class="modal-header"> - <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">×</span></button> - <h4 class="modal-title" id="addEntityModalLabel">Ajouter une entité</h4> - </div> - <div class="modal-body"> - <form class="form-horizontal"> + </div> + </md-tab> + <md-tab *ngIf="!creationMode" label="Signature(s)"> + <div class="col-md-6 col-md-offset-3"> <div class="form-group"> - <div class="col-sm-6"> - <select id="entitiesSelect" class="form-control"> - <option>Choisissez une entité</option> - <option *ngFor="let entity of user.allEntities" [disabled]="entity.disabled">{{entity.entity_label}}</option> - </select> - </div> - <div class="col-sm-6"> - <input class="form-control" id="entityRole" placeholder="Rôle" type="text"> - </div> + <button (click)="clickOnUploader('uploadSignFile')" mdTooltip="taille de 2 mo maximum" class="form-control btn btn-sm btn-success" + style="width:auto;"> + <i class="fa fa-plus"></i> Ajouter une signature + </button> </div> - </form> - </div> - <div class="modal-footer"> - <button (click)="addEntity()" type="button" class="btn btn-success" >{{lang.validate}}</button> - </div> - </div> - </div> -</div> - -<div id="manageAbs" class="modal fade bs-example-modal-lg" tabindex="-1" role="dialog" aria-labelledby="myLargeModalLabel"> - <div class="modal-dialog modal-lg" role="document"> - <div class="modal-content"> - <div class="modal-header"> - <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">×</span></button> - <h4 class="modal-title" id="myModalLabel">{{lang.manageAbsences}}</h4> - </div> - <div class="modal-body"> - <nav class="navbar navbar-default"> - <div class="container-fluid"> - <form class="navbar-form navbar-left"> - <div class="form-group"> - <select id="selectBasketAbsenceUser" class="form-control"> - <option>{{lang.chooseBasket}}</option> - <option *ngFor="let basket of user.baskets" [disabled]="basket.disabled"> - {{basket.basket_name}} - <span *ngIf="basket.group_id">({{basket.group_id}})</span> - <span *ngIf="basket.userToDisplay">({{basket.userToDisplay}})</span> - </option> - </select> - <span> {{lang.to}} </span> - </div> - <div class="form-group typeahead__container"> - <div class="typeahead__field"> - <input id="absenceUser" type="text" class="form-control" placeholder="{{lang.user}}" autocomplete="off"> - </div> - </div> - </form> - <ul class="nav navbar-nav navbar-right" (click)="addBasketRedirection()" style="cursor: pointer"> - <li><a title="{{lang.save}}"><i class="fa fa-plus"></i></a></li> - </ul> - </div> - </nav> - <ul class="list-group"> - <li class="list-group-item" *ngFor="let uam of userAbsenceModel; let i = index"> - <i class="fa fa-tasks" title="{{uam.basketId}}"></i> {{uam.basketName}} - <span class="pull-right"> - <span class="label label-primary">{{uam.newUser}}</span> - <a (click)="delBasketRedirection(i)" style="cursor: pointer" title="{{lang.delete}}"><i class="fa fa-trash" style="color:red;"></i></a> - </span> - </li> - </ul> - </div> - <div class="modal-footer"> - <button type="button" (click)="activateAbsence()" class="btn btn-default">{{lang.activateAbsence}}</button> - </div> - </div> - </div> -</div> - -<div id="manageSign" class="modal fade bs-example-modal-lg" tabindex="-1" role="dialog" aria-labelledby="myLargeModalLabel"> - <div class="modal-dialog modal-lg" role="document"> - <div class="modal-content"> - <div class="modal-header"> - <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">×</span></button> - <h4 class="modal-title">{{lang.manageSignatures}}</h4> - </div> - <div class="modal-body"> - <ul class="nav nav-tabs" role="tablist"> - <li role="presentation" class="active"><a href="#signatureBookSign" aria-controls="signatureBookSign" role="tab" data-toggle="tab">{{lang.sbSignatures}}</a></li> - </ul> - <div class="tab-content"> - <div role="tabpanel" class="tab-pane active" id="signatureBookSign"> - <div class="row" style="margin-top:5px;"> + <div class="form-group"> + <div class="row" style="margin-top:5px;display:none;"> <form (ngSubmit)="submitSignature()" #signatureForm="ngForm"> <div class="col-md-11"> - <input type="text" [(ngModel)]="signatureModel.label" id="signLabel" name="label" placeholder="{{lang.label}}" class="form-control" required> + <input type="text" [(ngModel)]="signatureModel.label" id="signLabel" name="label" placeholder="{{lang.label}}" class="form-control" + required> <div class="form-inline hide"> <div class="form-group"> <input type="file" name="files[]" id="uploadSignFile" (change)="uploadSignatureTrigger($event)" accept="image/*"> @@ -272,50 +182,71 @@ </div> <div class="col-md-1" style="margin-bottom:5px;"> <button class="form-control btn btn-sm btn-success" type="submit" [disabled]="!signatureForm.form.valid || !signatureModel.size"> - <i class="fa fa-plus"></i> - </button> + <i class="fa fa-plus"></i> + </button> </div> <div [ngClass]="[signatureModel.size != '' ? 'col-md-10' : 'col-md-12']"> <div class="upload-drop-zone" (click)="clickOnUploader('uploadSignFile')" style="cursor:pointer"> - {{lang.clickOn}} <i class="fa fa-upload fa-2x"></i> - (< 2MB) + {{lang.clickOn}} <i class="fa fa-upload fa-2x"></i> ( + < 2MB) </div> </div> - </div> - <div class="col-md-2" *ngIf="signatureModel.size"> - <img id="signaturePreview" src="{{signatureModel.base64ForJs}}" alt="Invalid image" style="width: 100%;"> - </div> - </form> - </div> - <div class="row" id="signList"> - <div *ngFor="let signature of user.signatures; let i = index" class="col-md-3"> - <div class="thumbnail"> - <img src="{{signature.pathToSignatureOnTmp}}" alt="Signature" style="width:auto;height:60px;"> - <div class="caption" style="margin-bottom:0px;"> - <div *ngIf="selectedSignature != i"> - <p title="{{signature.signature_label}}" style="text-overflow: ellipsis;">{{signature.signature_label}}</p> - <a (click)="displaySignatureEditionForm(i)" class="btn btn-success" role="button" title="{{lang.update}}"> - <i class="fa fa-edit"></i> - </a> - <a (click)="deleteSignature(signature.id)" class="btn btn-danger" role="button" title="{{lang.delete}}"> - <i class="fa fa-trash"></i> - </a> - </div> - <div *ngIf="selectedSignature == i"> - <input type="text" [(ngModel)]="selectedSignatureLabel" name="selectedSignatureLabel" placeholder="{{lang.label}}" class="form-control" style="margin-bottom: 10px; font-size: 12px;height:28px"> - <button (click)="updateSignature()" type="button" class="btn btn-success" [disabled]="!selectedSignatureLabel" title="{{lang.update}}"> - <i class="fa fa-check"></i> - </button> - <button (click)="selectedSignature = -1" type="button" class="btn btn-warning" title="{{lang.cancel}}"> - <i class="fa fa-times"></i> - </button> - </div> + <div class="col-md-2" *ngIf="signatureModel.size"> + <img id="signaturePreview" src="{{signatureModel.base64ForJs}}" alt="Invalid image" style="width: 100%;"> </div> + </form> + </div> + <div id="signList"> + <div *ngFor="let signature of user.signatures; let i = index" class="col-md-4" style="margin-bottom:10px;"> + <md-card> + <md-card-header> + <md-card-title> + <md-input-container> + <input mdInput type="text" [(ngModel)]="signature.signature_label" name="selectedSignatureLabel" placeholder="{{lang.label}}" + (focusout)="updateSignature(i)"> + </md-input-container> + </md-card-title> + <i class="fa fa-times text-danger" style="cursor:pointer;" (click)="deleteSignature(signature)"></i> + </md-card-header> + + + <md-card-content> + <img src="{{signature.pathToSignatureOnTmp}}" alt="Signature" style="width:100%;height:60px;"> + </md-card-content> + </md-card> </div> + <div class="clearfix"></div> </div> </div> </div> - </div> - </div> + </md-tab> + <md-tab label="Historique"> + <div class="col-md-12"> + <table id="hisotryTable" class="table table-hover table-condensed" [md2Data]="data | dataPipe : 'info' : search" #md2="md2DataTable" [sortBy]='event_date' [rowsPerPage]="10"> + <thead> + <tr> + <td> + <md2-pagination></md2-pagination> + </td> + <td style="text-align:right;"> + <md-input-container> + <input mdInput placeholder="{{lang.filterBy}} : {{lang.desc}}" class="searchTable" [(ngModel)]="search" /> + </md-input-container> + </td> + </tr> + <tr> + <th md2SortBy="event_date">{{lang.date}}</th> + <th md2SortBy="info">{{lang.desc}}</th> + </tr> + </thead> + <tbody> + <tr *ngFor="let history of md2.data"> + <td style="vertical-align:middle;">{{history.event_date | date : "dd/MM/y HH:mm"}}</td> + <td style="vertical-align:middle;">{{history.info}}</td> + </tr> + </tbody> + </table> + </div> + </md-tab> + </md-tab-group> </div> - </div> -</div> + </div> \ No newline at end of file diff --git a/apps/maarch_entreprise/Views/users-administration.component.html b/apps/maarch_entreprise/Views/users-administration.component.html index 3fe20b3a770fdc79b92ec8f96465df4c280cb11d..6c77df645fc015dbd16dd505a36c703aeb576df7 100755 --- a/apps/maarch_entreprise/Views/users-administration.component.html +++ b/apps/maarch_entreprise/Views/users-administration.component.html @@ -1,72 +1,71 @@ + +<div class="page-header"> + <h1>{{lang.administration}} {{lang.users}} <small>{{data.length}} {{lang.users}}</small></h1> +</div> <div *ngIf="loading"> - <i class="fa fa-spinner fa-spin fa-5x" style="margin-left: 50%;margin-top: 16%;font-size: 8em"></i> + <md-spinner style="margin:auto;"></md-spinner> </div> <div *ngIf="!loading" class="container-fluid"> - <h1 style="margin-top: 0"><i class="fa fa-user fa-2x"></i> {{lang.admin}} {{lang.users}} : {{users.length}} {{lang.users}}</h1> - <nav class="navbar navbar-default" style="font-size:17px !important;" id="toolBox"> - <div class="container-fluid"> - <div class="navbar-header"> - <a class="navbar-brand" routerLink="/administration" style="cursor: pointer"> - <i class="fa fa-arrow-circle-left" title="{{lang.back}}"></i> - </a> - </div> - <div class="collapse navbar-collapse" id="bs-example-navbar-collapse-1"> - <ul class="nav navbar-nav navbar-right"> - <li style="cursor: pointer" routerLink="/administration/users/new"> - <a title="{{lang.addUser}}"><i class="fa fa-user-plus"></i></a> - </li> - </ul> - </div> - </div> - </nav> - <div class="col-md-12" style="margin-top: 1%"> - <table id="usersTable" class="display" style="width: 100%" cellspacing="0" border="0"> - <thead> - <tr> - <th style="width:15%;" valign="bottom" align="left"><span>{{lang.identifier}}</span></th> - <th style="width:20%;" valign="bottom" align="left"><span>{{lang.lastname}}</span></th> - <th style="width:20%;" valign="bottom" align="left"><span>{{lang.firstname}}</span></th> - <th style="width:5%;" valign="bottom" align="left"><span>{{lang.status}}</span></th> - <th style="width:20%;" valign="bottom" align="left"><span>{{lang.mail}}</span></th> - <th style="width:20%;"><span> </span></th> - </tr> - </thead> - <tbody> - <tr *ngFor="let user of users" id="{{user.user_id}}"> - <td>{{user.user_id}}</td> - <td>{{user.lastname}}</td> - <td>{{user.firstname}}</td> - <td> - <span *ngIf="user.status == 'OK' && user.enabled == 'Y'" class="label label-primary">{{lang.active}}</span> - <span *ngIf="user.enabled == 'N'" class="label label-danger">{{lang.inactive}}</span> - <span *ngIf="user.status == 'ABS'" class="label label-warning">{{lang.abs}}</span> - </td> - <td>{{user.mail}}</td> - <td style="text-align:right;"> - <div class="btn-group" role="group" aria-label="..."> - <button routerLink="/administration/users/{{user.id}}" type="button" class="btn btn-default" title="{{lang.edit}}"> - <a><i style="cursor:pointer" class="fa fa-edit"></i></a> - </button> - <button *ngIf="user.enabled == 'Y' && user.inDiffListDest == 'Y'" data-toggle="modal" data-target="#changeDiffListDest" type="button" class="btn btn-default" title="{{lang.suspend}}" (click)="suspendUser(user)"> - <a><i style="cursor:pointer;color:#f0ad4e;" class="fa fa-pause"></i></a> - </button> - <button *ngIf="user.enabled == 'Y' && user.inDiffListDest == 'N'" type="button" class="btn btn-default" title="{{lang.suspend}}" (click)="suspendUser(user)"> - <a><i style="cursor:pointer;color:#f0ad4e;" class="fa fa-pause"></i></a> - </button> + <div class="col-md-12"> + <table id="usersTable" class="table table-hover table-condensed" [md2Data]="data | dataPipe : 'user_id' : search" #md2="md2DataTable" [sortBy]='user_id' [rowsPerPage]="10"> + <thead> + <tr> + <td colspan="5"> + <md2-pagination></md2-pagination> + </td> + <td style="text-align:right;"> + <md-input-container> + <input mdInput placeholder="{{lang.filterBy}} : {{lang.id}}" class="searchTable" [(ngModel)]="search" /> + </md-input-container> + + <a class="text-primary" style="cursor: pointer" routerLink="/administration/users/new" title="{{lang.addUser}}"><i class="fa fa-user-plus fa-2x"></i></a> + </td> + </tr> + <tr> + <th md2SortBy="user_id">{{lang.id}}</th> + <th md2SortBy="lastname">{{lang.lastname}}</th> + <th md2SortBy="firstname">{{lang.firstname}}</th> + <th md2SortBy="status">{{lang.status}}</th> + <th md2SortBy="mail">{{lang.email}}</th> + <th> </th> + </tr> + </thead> + <tbody> + <tr *ngFor="let user of md2.data"> + <td style="vertical-align:middle;">{{user.user_id}}</td> + <td style="vertical-align:middle;">{{user.lastname}}</td> + <td style="vertical-align:middle;">{{user.firstname}}</td> + <td style="vertical-align:middle;"> + <span *ngIf="user.status == 'OK' && user.enabled == 'Y'" class="label label-primary">{{lang.active}}</span> + <span *ngIf="user.enabled == 'N'" class="label label-danger">{{lang.inactive}}</span> + <span *ngIf="user.status == 'ABS'" class="label label-warning">{{lang.abs}}</span> + </td> + <td style="vertical-align:middle;">{{user.mail}}</td> + <td style="text-align:right;"> + <div class="btn-group" role="group" aria-label="..."> + <button routerLink="/administration/users/{{user.id}}" type="button" class="btn btn-default" title="{{lang.edit}}"> + <a><i style="cursor:pointer" class="fa fa-edit"></i></a> + </button> + <button *ngIf="user.enabled == 'Y' && user.inDiffListDest == 'Y'" data-toggle="modal" data-target="#changeDiffListDest" type="button" class="btn btn-default" title="{{lang.suspend}}" (click)="suspendUser(user)"> + <a><i style="cursor:pointer;color:#f0ad4e;" class="fa fa-pause"></i></a> + </button> + <button *ngIf="user.enabled == 'Y' && user.inDiffListDest == 'N'" type="button" class="btn btn-default" title="{{lang.suspend}}" (click)="suspendUser(user)"> + <a><i style="cursor:pointer;color:#f0ad4e;" class="fa fa-pause"></i></a> + </button> - <button *ngIf="user.enabled == 'N'" type="button" class="btn btn-default" title="{{lang.authorize}}" (click)="activateUser(user)"> - <a><i style="cursor:pointer;color:#5cb85c;" class="fa fa-check"></i></a> - </button> - <button *ngIf="user.inDiffListDest == 'Y'" type="button" class="btn btn-default" title="{{lang.delete}}" data-toggle="modal" data-target="#changeDiffListDest" (click)="deleteUser(user)"> - <a><i style="cursor:pointer;color: #D9534F" class="fa fa-trash"></i></a> - </button> - <button *ngIf="user.inDiffListDest == 'N'" type="button" class="btn btn-default" title="{{lang.delete}}" (click)="deleteUser(user)"> - <a><i style="cursor:pointer;color: #D9534F" class="fa fa-trash"></i></a> - </button> - </div> - </td> - </tr> - </tbody> + <button *ngIf="user.enabled == 'N'" type="button" class="btn btn-default" title="{{lang.authorize}}" (click)="activateUser(user)"> + <a><i style="cursor:pointer;color:#5cb85c;" class="fa fa-check"></i></a> + </button> + <button *ngIf="user.inDiffListDest == 'Y'" type="button" class="btn btn-default" title="{{lang.delete}}" data-toggle="modal" data-target="#changeDiffListDest" (click)="deleteUser(user)"> + <a><i style="cursor:pointer;color: #D9534F" class="fa fa-trash"></i></a> + </button> + <button *ngIf="user.inDiffListDest == 'N'" type="button" class="btn btn-default" title="{{lang.delete}}" (click)="deleteUser(user)"> + <a><i style="cursor:pointer;color: #D9534F" class="fa fa-trash"></i></a> + </button> + </div> + </td> + </tr> + </tbody> </table> </div> </div> @@ -84,16 +83,15 @@ <b>{{this.userDestRedirect.firstname}} {{this.userDestRedirect.lastname}}</b> est en <b>destinataire</b> des modèles liste de difffusion suivante, veuillez choisir un utilisateur de <b>remplacement</b> : </div> <div *ngFor="let userDestRedirectModel of userDestRedirectModels" id="{{userDestRedirectModel.object_id}}" class="form-group"> - <div class="input-group input-group-sm"> - <span class="input-group-addon" id="sizing-addon1"><i class="fa fa-share-alt-square"></i> {{userDestRedirectModel.object_id}} - {{userDestRedirectModel.description}}</span> - <div class="form-group typeahead__container" style="margin-bottom:0px;"> - <div class="typeahead__field"> - <input name="redirectDest_{{userDestRedirectModel.object_id}}" [(ngModel)]="userDestRedirectModel.redirectUserId" type="text" class="form-control redirectDest" placeholder="Utilisateur" autocomplete="off" aria-describedby="sizing-addon1" required> - </div> - </div> - </div> - </div> - + <md2-autocomplete name="userList" + [items]="data" + item-text="user_id" + item-value="user_id" + placeholder="nouveau destinataire pour : {{userDestRedirectModel.title}}" + [(ngModel)]="userDestRedirectModel.redirectUserId" + required> + </md2-autocomplete> + </div> </div> <div class="modal-footer"> <button *ngIf="userDestRedirect.mode == 'del'" type="button" class="btn btn-danger" (click)="deleteUserModal(userDestRedirect)" [disabled]="!changeDiffListDestForm.form.valid">{{lang.delete}} {{lang.user}}</button> diff --git a/apps/maarch_entreprise/admin/history/history.php b/apps/maarch_entreprise/admin/history/history.php index d623789e7fa590eef226a97e8986b7e87d51fc60..9f116380226ec02ef8cb29c02621d19971619f48 100755 --- a/apps/maarch_entreprise/admin/history/history.php +++ b/apps/maarch_entreprise/admin/history/history.php @@ -51,12 +51,12 @@ $core_tools2->manage_location_bar($page_path, $page_label, $page_id, $init, $lev /***********************************************************/ $db = new Database(); -$where = ''; +$where = ''; $arrayPDO = array(); -$label = ''; -$tab = array(); -$modules = array(); -$stmt = $db->query("SELECT DISTINCT id_module FROM ".$_SESSION['tablename']['history']); +$label = ''; +$tab = array(); +$modules = array(); +$stmt = $db->query("SELECT DISTINCT ON(lower(id_module)) id_module FROM history WHERE id_module NOT IN ('null') ORDER BY lower(id_module)"); while ($res = $stmt->fetchObject()) { if ($res->id_module == 'admin') { array_push($modules, array('id' => 'admin', 'label' => _ADMIN)); @@ -124,7 +124,7 @@ if (isset($_REQUEST['search']) || $history_module=$_SESSION['m_admin']['history']['module']; } if (!empty($history_module)) { - $where .= " ".$_SESSION['tablename']['history'].".id_module = ? and"; + $where .= " lower(".$_SESSION['tablename']['history'].".id_module) = lower(?) and"; $arrayPDO = array_merge($arrayPDO, array($history_module)); } } diff --git a/apps/maarch_entreprise/class/class_contacts_v2_Abstract.php b/apps/maarch_entreprise/class/class_contacts_v2_Abstract.php index 0e389c1a67096b3133645bc8108000f40c232406..4620522b8e16ff1958c68269a06a7d1577756e29 100755 --- a/apps/maarch_entreprise/class/class_contacts_v2_Abstract.php +++ b/apps/maarch_entreprise/class/class_contacts_v2_Abstract.php @@ -501,9 +501,13 @@ abstract class contacts_v2_Abstract extends Database <table id="frmcontact_table"> <tr> <td> </td> - <td class="indexing_field"> - <input type="radio" class="check" name="is_corporate" value="Y" <?php if($_SESSION['m_admin']['contact']['IS_CORPORATE_PERSON'] == 'Y'){?> checked="checked"<?php } ?>/ onclick="javascript:show_admin_contacts( true, '<?php functions::xecho($display_value);?>');setContactType('corporate', '<?php echo ($can_add_contact);?>')" id="corpo_yes"><span onclick="$j('#corpo_yes').click();" onmouseover="this.style.cursor='pointer';"><?php echo _IS_CORPORATE_PERSON;?></span> - <input type="radio" class="check" name="is_corporate" value="N" <?php if($_SESSION['m_admin']['contact']['IS_CORPORATE_PERSON'] == 'N'){?> checked="checked"<?php } ?> onclick="javascript:show_admin_contacts( false, '<?php functions::xecho($display_value);?>');setContactType('no_corporate', '<?php echo ($can_add_contact);?>')" id="corpo_no"><span onclick="$j('#corpo_no').click();" onmouseover="this.style.cursor='pointer';"><?php echo _INDIVIDUAL;?></span> + <td class="indexing_field" style="text-align:center"> + <span id="span_corporate"> + <input type="radio" class="check" name="is_corporate" value="Y" <?php if($_SESSION['m_admin']['contact']['IS_CORPORATE_PERSON'] == 'Y'){?> checked="checked"<?php } ?>/ onclick="javascript:show_admin_contacts( true, '<?php functions::xecho($display_value);?>');setContactType('corporate', '<?php echo ($can_add_contact);?>')" id="corpo_yes"><span onclick="$j('#corpo_yes').click();" onmouseover="this.style.cursor='pointer';"><?php echo _IS_CORPORATE_PERSON;?></span> + </span> + <span id="span_no_corporate"> + <input type="radio" class="check" name="is_corporate" value="N" <?php if($_SESSION['m_admin']['contact']['IS_CORPORATE_PERSON'] == 'N'){?> checked="checked"<?php } ?> onclick="javascript:show_admin_contacts( false, '<?php functions::xecho($display_value);?>');setContactType('no_corporate', '<?php echo ($can_add_contact);?>')" id="corpo_no"><span onclick="$j('#corpo_no').click();" onmouseover="this.style.cursor='pointer';"><?php echo _INDIVIDUAL;?></span> + </span> </td> <td> </td> <td> </td> @@ -521,11 +525,13 @@ abstract class contacts_v2_Abstract extends Database </tr> <?php }?> + <script type="text/javascript"> </script> <tr id="contact_types_tr" > <td><?php echo _CONTACT_TYPE;?> :</td> <td class="indexing_field"> <select name="contact_type" id="contact_type" - <?php if($mode == "add"){ + + <?php if($mode == "add"){ ?> onchange="getContacts('<?php echo $_SESSION['config']['businessappurl'];?>index.php?display=true&dir=my_contacts&page=getContacts', this.options[this.selectedIndex].value, 'view');" <?php } ?> > @@ -649,7 +655,25 @@ abstract class contacts_v2_Abstract extends Database </p> </form> - <script type="text/javascript">setContactType("<?php if(isset($_SESSION['m_admin']['contact']['IS_CORPORATE_PERSON']) && $_SESSION['m_admin']['contact']['IS_CORPORATE_PERSON'] == 'N' ){ echo 'no_corporate'; } else { echo 'corporate'; }?>", '<?php echo ($can_add_contact);?>');</script> + <script type="text/javascript"> + if(!checkContactType('no_corporate','<?php echo ($can_add_contact);?>')) + { + $j('#span_no_corporate').css('display','none'); + } else { + setContactType('no_corporate',''); + $j('#corpo_no').prop('checked',true); + } + if(!checkContactType('corporate','<?php echo ($can_add_contact);?>')) + { + $j('#span_corporate').css('display','none'); + } else { + setContactType('corporate',''); + $j('#corpo_yes').prop('checked',true); + } + + + </script> + <?php if($mode=="up" && $admin) diff --git a/apps/maarch_entreprise/class/class_indexing_searching_app_Abstract.php b/apps/maarch_entreprise/class/class_indexing_searching_app_Abstract.php index a12047dfc2d2ae66d2250de8ddfe5a2ea5da5304..f2b981de7a3ce5804a1cc6bc9599eb6403b38176 100755 --- a/apps/maarch_entreprise/class/class_indexing_searching_app_Abstract.php +++ b/apps/maarch_entreprise/class/class_indexing_searching_app_Abstract.php @@ -293,20 +293,30 @@ abstract class indexing_searching_app_Abstract extends Database $_SESSION['error'] .= $_ENV['categories'][$cat_id]['other_cases']['process_limit_date']['label']." "._WRONG_FORMAT; } if (!empty($post['process_limit_date'])) { - - $processLimitDate = new datetime($post['process_limit_date']); - $processLimitDate = date_add($processLimitDate,date_interval_create_from_date_string('23 hours + 59 minutes + 59 seconds')); - $processLimitDate = (array) $processLimitDate; - - array_push( - $data_ext, - array( - 'column' => 'process_limit_date', - 'value' => $func->format_date_db($processLimitDate['date'],'true','','true'), - 'type' => "date" - ) - ); - } + $processLimitDate = new datetime($post['process_limit_date']); + $processLimitDate = date_add($processLimitDate,date_interval_create_from_date_string('23 hours + 59 minutes + 59 seconds')); + $processLimitDate = (array) $processLimitDate; + + array_push( + $data_ext, + array( + 'column' => 'process_limit_date', + 'value' => $func->format_date_db($processLimitDate['date'],'true','','true'), + 'type' => "date" + ) + ); + } + else + { + array_push( + $data_ext, + array( + 'column' => 'process_limit_date', + 'value' => null, + 'type' => "date" + ) + ); + } if ($core->is_module_loaded('folder')) { diff --git a/apps/maarch_entreprise/class/class_lists_Abstract.php b/apps/maarch_entreprise/class/class_lists_Abstract.php index e01e4a7284c1bb7fb82462765b2f6fa68224c8b7..48b5c7d37aa0ac7342c99b2c53a9167719972088 100755 --- a/apps/maarch_entreprise/class/class_lists_Abstract.php +++ b/apps/maarch_entreprise/class/class_lists_Abstract.php @@ -1262,10 +1262,10 @@ abstract class lists_Abstract extends Database $href = $this->_buildMyLink($this->params['viewDocumentLink'], $resultTheLine, $listKey); if ($core->is_module_loaded('thumbnails') === true && !$isAttachment){ $return .= '<div align="center" class="iconDoc" onmouseover="showThumb(\'thumb_\',\'' . $res_id . '\', \'letterbox_coll\')"><a href="'.$href.'" target="_blank" title="' - ._VIEW_DOC.'"><i class="fa fa-download fa-2x" title="' . _VIEW_DOC . '"></i><span id="thumb_' . $res_id . '" name="thumb_' . $res_id . '"></span></a></div>'; + ._VIEW_DOC.'"><i class="tooltip fa fa-download fa-2x" title="' . _DOWNLOAD_LOCAL_DOC_COPY . '"></i><span id="thumb_' . $res_id . '" name="thumb_' . $res_id . '"></span></a></div>'; } - else $return .= '<div align="center" class="iconDoc"><a href="'.$href.'" target="_blank" title="' - ._VIEW_DOC.'"><i class="fa fa-download fa-2x" title="' . _VIEW_DOC . '"></i></a></div>'; + else $return .= '<div align="right" class="iconDoc" style="" ><a href="'.$href.'" target="_blank" title="' + ._VIEW_DOC.'"><i class="tooltip fa fa-download fa-2x" title="' . _DOWNLOAD_LOCAL_DOC_COPY . '"></i></a></div>'; return $return; } @@ -1606,10 +1606,11 @@ abstract class lists_Abstract extends Database $return = '<a href="' . $_SESSION['config']['businessappurl'] . 'index.php?display=true' . '&module=attachments&page=del_attachment&relation=' . $resultTheLine[1]['value'] . '&id=' . $resultTheLine[0]['value'].'&fromDetail='.$fromDetail.'" class="delete"' . 'onclick="return(confirm(\'' . _REALLY_DELETE . ' ?\n\r\n\r' - . _DEFINITIVE_ACTION . '\'));"><i class="fa fa-trash-o fa-lg" title="'._DELETE.'"></i></a>'; + . _DEFINITIVE_ACTION . '\'));"><i class="tooltip fa fa-trash-o fa-2x" title="'._DELETE.'"></i></a>'; }else{ - $return = '<a href="" class="delete" style="visibility:hidden;"><i class="fa fa-trash-o fa-lg" title="'._DELETE.'"></i></a>'; + $return = '<a href="" class="delete" style="visibility:hidden;"><i class="tooltip fa fa-trash-o fa-2x" title="'._DELETE.'"></i></a>'; } + $return .= '<script>titleWithTooltipsterClass("tooltip");</script>'; return $return; } @@ -1634,12 +1635,12 @@ abstract class lists_Abstract extends Database $core_tools = new core_tools(); if (($core_tools->test_service('modify_attachments', 'attachments', false) || $typist == $_SESSION['user']['UserId']) && $status <> "TRA") { - $return = '<a href="javascript://" class="change" onclick="modifyAttachmentsForm(\'' . $_SESSION['config']['businessappurl'] + $return = '<a style="padding-left:10px;" href="javascript://" class="change" onclick="modifyAttachmentsForm(\'' . $_SESSION['config']['businessappurl'] . 'index.php?display=true&module=attachments&page=attachments_content&id=' . $resultTheLine[0]['value'] . '&relation='.$relation.'&fromDetail='.$fromDetail.'\',\'98%\',\'auto\');"> - <i class="fa fa-pencil fa-lg" title="'._MODIFY.'"></i></a>'; + <i class="tooltip fa fa-pencil fa-2x fa-lg" title="'._MODIFY.'"></i></a>'; }else{ $return = '<a href="javascript://" disabled="disabled" class="change" style="visibility:hidden;"> - <i class="fa fa-pencil fa-lg" title="'._MODIFY.'"></i></a>'; + <i class="tooltip fa fa-pencil fa-2x" title="'._MODIFY.'"></i></a>'; } return $return; @@ -1668,7 +1669,8 @@ abstract class lists_Abstract extends Database $fromDetail = $resultTheLine[$iresults]['fromDetail']; } } - $return = '<input type="checkbox" name="final" id="final" '; + $return = '<input type="checkbox" name="final" id="final" align="left"'; + if ($resultTheLine[2]['value_bis'] == "TRA") { $return .= 'checked '; diff --git a/apps/maarch_entreprise/css/action-administration.component.css b/apps/maarch_entreprise/css/action-administration.component.css index e69de29bb2d1d6434b8b29ae775ad8c2e48c5391..8b137891791fe96927ad78e64b0aad7bded08bdc 100755 --- a/apps/maarch_entreprise/css/action-administration.component.css +++ b/apps/maarch_entreprise/css/action-administration.component.css @@ -0,0 +1 @@ + diff --git a/apps/maarch_entreprise/css/engine.css b/apps/maarch_entreprise/css/engine.css index b89c98bfd04e3661ca3a69a068a5492f7bfdd445..73c46878603020f861277daec2fc5fcf89b7215f 100755 --- a/apps/maarch_entreprise/css/engine.css +++ b/apps/maarch_entreprise/css/engine.css @@ -1,180 +1,108 @@ -/*HeaderV2*/ -#headerV2 .nav .open > a, .nav .open > a:focus, .nav .open > a:hover{ - background-color: inherit !important; -} - -/* Alert info*/ -#resultInfo{ - top :10px; - text-align: center; - position: fixed; - width: 30%; - right: 10px; - z-index: 1051; - -moz-box-shadow: 0px 0px 5px 0px #656565; - -webkit-box-shadow: 0px 0px 5px 0px #656565; - -o-box-shadow: 0px 0px 5px 0px #656565; - box-shadow: 0px 0px 5px 0px #656565; - filter:progid:DXImageTransform.Microsoft.Shadow(color=#656565, Direction=NaN, Strength=5); -} -form .form-group{ - margin-bottom: 15px; +/******* CORECTION BUG CSS WITH V1 (A SUPPRIMER A LA FIN) *********/ +.page-header h1{ + margin-top: 10px !important; } -/* toolbox in admin */ -#toolBox{ - margin-top:10px !important; - margin-bottom: 10px !important; -} - -/* modal part */ -.modal-content{ - background-color: #009DC5 !important; -} -.modal-header h4{ - color: white !important; -} -.modal-body{ - background-color: white; - padding:10px; - min-height: 200px; - max-height: 70vh; - overflow: hidden; - overflow-y: auto; +#menu{ + margin-top: 35px !important; } -.modal-body .list-group li{ - /*border-color: #009DC5 !important;*/ - font-weight: bold; +#menunav{ + font-size: 90% !important; } -.modal-footer{ - background:white; +#menu span{ + background-size: 45% !important; } -/* datatables part */ -table.dataTable thead .sorting { - background-image: url("../../node_modules/datatables/media/images/sort_both.png")!important; -} -table.dataTable thead .sorting_asc { - background-image: url("../../node_modules/datatables/media/images/sort_asc.png")!important; -} -table.dataTable thead .sorting_desc { - background-image: url("../../node_modules/datatables/media/images/sort_desc.png")!important; -} -table.dataTable thead .sorting_asc_disabled { - background-image: url("../../node_modules/datatables/media/images/sort_asc_disabled.png")!important; -} -table.dataTable thead .sorting_desc_disabled { - background-image: url("../../node_modules/datatables/media/images/sort_desc_disabled.png")!important; -} -.datatablesCenter .dataTables_paginate{ - float:none !important; - text-align: center !important; -} -.dataTables_wrapper .dataTables_paginate .paginate_button.current, .dataTables_wrapper .dataTables_paginate .paginate_button.current:hover{ - background:#FDD16C !important; - border:none !important; - color:white !important; -} -.dataTables_wrapper .dataTables_paginate .paginate_button:hover :not(.disabled) :not(.current){ - background: white !important; - border:solid 1px white !important; - border-radius: 2px !important; - color:#333 !important; -} -.dataTables_wrapper .dataTables_paginate .paginate_button:active{ - background: none !important; - box-shadow: none !important; +#gauchemenu{ + top: 28px !important; + height: 38px !important; } -.dataTables_wrapper .dataTables_paginate .paginate_button:hover :not(.disabled) :not(.current) i{ - color: #009DC5 !important; +#logo{ + height: 66px !important; } -.dataTables_wrapper .dataTables_paginate .paginate_button:active :not(.disabled) :not(.current) i{ - color: #FDD16C !important; +#menunav{ + width: 264px !important; } -.dataTables_wrapper .dataTables_paginate .paginate_button .disabled:hover{ - background: none !important; - border:solid 1px white !important; - border-radius: 2px !important; +#ariane{ + top: -5px !important; + font-size: 0.8em !important; } -table.dataTable.display tbody tr.odd { - background-color: #DEEDF3 !important; +.footer_menu{ + font-size: 0.7em !important; + height: 18px !important; } -table.dataTable.hover tbody tr.even:hover, table.dataTable.display tbody tr.even:hover{ - background-color: #fff !important; -} -table.dataTable.hover tbody tr.odd:hover, table.dataTable.display tbody tr.odd:hover{ - background-color: #DEEDF3 !important; -} -table.dataTable.display tbody tr.odd > .sorting_1, table.dataTable.order-column.stripe tbody tr.odd > .sorting_1 { - background-color: #DEEDF3 !important; -} -table.dataTable.display tbody tr.even > .sorting_1, table.dataTable.order-column.stripe tbody tr.even > .sorting_1 { - background-color: #DEEDF3 !important; +/************************************************************/ + +.page-header{ + margin-top: 0px; } -table.dataTable thead th, table.dataTable thead td { - border-bottom: 1px solid #009DC5 !important; + +.page-header h1{ + font-size: 30px; } -table.dataTable.no-footer { - border-bottom: 1px solid #009DC5 !important; + +#container{ + padding: 0px !important; } -table.dataTable thead th, table.dataTable tfoot th { - color: #009DC5 !important; +.md2-toast { + display: table; + background-color: #337ab7 !important; + vertical-align: middle; + /*background-color: rgba(63, 81, 181, 0.6) !important;*/ + /*background-color: rgba(0, 0, 0, 0.6) !important;*/ } -a.next{ - background-image: none !important; + +.md2-toast i{ + display: table-cell; + padding:5px; + vertical-align: middle; } -.dataTables_info{ - float: none !important; - color:#666 !important; + +.md2-toast span{ + display: table-cell; + padding:5px; + vertical-align: middle; } -.dataTables_filter input{ - font-size: inherit; +.mat-input-container,.md2-select,md2-datepicker{ + width:100% !important; } -.dataTables_length{ - float:none !important; + +.md2-select{ + padding-bottom: 1.29688em; } -.dataTables_length select{ - width:auto !important; + +.mat-tab-body-wrapper{ + padding: 10px; } -.tooltipster-sidetip.tooltipster-maarch .tooltipster-box { - background: white; - border: solid 2px #009DC5; - border-radius: 3px; - box-shadow: 5px 5px 2px 0 rgba(0,0,0,0.4); - width: 300px; +table tr:not(.filters) .mat-input-container{ + width:200px !important; } -.tooltipster-sidetip.tooltipster-maarch .tooltipster-content { - color: #666; - padding: 8px; +/*HeaderV2*/ +#headerV2 .nav .open > a, .nav .open > a:focus, .nav .open > a:hover{ + background-color: inherit !important; } -.help{ - background: none !important; - border: none !important; +/* modal part */ +.modal-content{ + background-color: #009DC5 !important; } -.help:active,.help:hover{ - background: none !important; - border: none !important; +.modal-header h4{ + color: white !important; } - -.help i{ - font-size: 10px; - position: relative; - top: -6px; - right: -6px; +.modal-body{ + background-color: white; + padding:10px; + min-height: 200px; + max-height: 70vh; + overflow: hidden; + overflow-y: auto; } - -.selectAll, .unselectAll{ - cursor: pointer; - float:left; +.modal-body .list-group li{ + /*border-color: #009DC5 !important;*/ + font-weight: bold; } - -.selectAll:active, .unselectAll:active{ - color: #009DC5 !important; +.modal-footer{ + background:white; } - -.mandatory{ - color:red; -} \ No newline at end of file diff --git a/apps/maarch_entreprise/css/header.component.css b/apps/maarch_entreprise/css/header.component.css index e4f9566d8a4765e308b71b048a4d5c72b9315ac1..172279e09776f577f79be7dbf7cd284ed1253c27 100755 --- a/apps/maarch_entreprise/css/header.component.css +++ b/apps/maarch_entreprise/css/header.component.css @@ -1,140 +1,14 @@ -#headerV2{ - border-radius:0px; - margin-left: -10px; - margin-top: 0px; - margin-right: -10px; - border: solid 2px #009DC5; - background: #009DC5; - color:white; +/deep/ .mat-toolbar-row .mat-icon-button { + margin-left: 5px; + margin-right: 5px; } -#headerV2 .navbar-right .dropdown-toggle{ - color:white !important; +/deep/ .mat-toolbar-row #globalSearch { + margin-left: 20px; } -#headerV2 .breadcrumb{ - padding:0px; - margin-bottom:0px; - background:none; - position:initial; +/deep/ .mat-toolbar-row .badge{ + margin-left: -15px; + margin-top: 10px; + background-color: #a94442 } -#ariane{ - position:initial; -} -#headerV2 .divider{ - background-color: #009DC5 !important; -} -#headerPos{ - margin-top: 3px; -} -#menuList{ - font-size:20px; - height: 40px; -} -#menuList .dropdown-toggle{ - padding-bottom: 8px; - color:white; - font-weight:bold; -} -#menuListContent{ - background-color: #CEE9F1; - border: solid 2px #009DC5; - box-shadow: none; - width: 247px; - padding-bottom: 0px; -} - -#menuListContent a{ - color: #0094D0; - font-size: 12px; - font-weight: normal; - letter-spacing: 0.02em; -} - -#headerPos .navbar-text{ - position: absolute; - margin: 0px; - padding: 15px; - padding-top: 5px; - background: #f2f2f2; - width: 80%; - height: 44px; - top: 26px; - border-top-left-radius: 3px; - left: 262px; - color: #009dc5; - font-weight: bold; - font-size: 1.3em; -} -#headerLogoPos{ - background-color:#f2f2f2; - margin-right:-30px; - margin-top:-34px; -} -#headerLogo{ - margin: 0px; - padding-right: 0px; - padding-top: 0px; - height: 56px; - width: 176px; - background: url(static.php?filename=default_nav_logo_maarch.gif) #f2f2f2; - background-size: 90%; - background-position: center; - background-repeat: no-repeat; -} - -#headerNotification .link{ - text-decoration: underline; - cursor: pointer; -} -#headerNotification .dropdown-menu .badge{ - font-size: 70%; -} -#headerNotification .alert-info a{ - color: #31708f !important; -} -#headerNotification .alert-warning a{ - color: #8a6d3b !important; -} -#headerNotification .alert-danger a{ - color: #a94442 !important; -} - -#menuListContentInfoUser{ - background-color: #1B91BA; - height: 15px; - width: 100%; - font-weight: bold; - font-size: 0.8em; - padding-right: 5px; - padding-left: 5px; - padding-top: 0px; - border-top: 2px solid #FFFFFF; - position: relative; - bottom: 0; -} - -#menuListContentInfoUser span{ - float:left; - font-weight: bold; - font-size: 0.8em; -} -#menuListContentInfoUser a{ - float:right; - font-weight: bold; - font-size: 0.8em; - clear: none; - color: white; - padding: 0px; -} -#menuListContentInfoUser a:hover,#menuListContentInfoUser a:focus{ - background-color: initial; -} - -.notification .badge { - background-color: #a94442; - font-size: 9px; - position: relative; - left: -10px; - top: 5px; -} \ No newline at end of file diff --git a/apps/maarch_entreprise/css/jstree-custom.min.css b/apps/maarch_entreprise/css/jstree-custom.min.css new file mode 100644 index 0000000000000000000000000000000000000000..89b68099e7cdf9daa024d9cc198ab7114227ea37 --- /dev/null +++ b/apps/maarch_entreprise/css/jstree-custom.min.css @@ -0,0 +1 @@ +.jstree-node,.jstree-children,.jstree-container-ul{display:block;margin:0;padding:0;list-style-type:none;list-style-image:none}.jstree-node{white-space:nowrap}.jstree-anchor{display:inline-block;color:#333;white-space:nowrap;padding:0 4px 0 1px;margin:0;vertical-align:top}.jstree-anchor:focus{outline:0}.jstree-anchor,.jstree-anchor:link,.jstree-anchor:visited,.jstree-anchor:hover,.jstree-anchor:active{text-decoration:none;color:inherit}.jstree-icon{display:inline-block;text-decoration:none;margin:0;padding:0;vertical-align:top;text-align:center}.jstree-icon:empty{display:inline-block;text-decoration:none;margin:0;padding:0;vertical-align:top;text-align:center}.jstree-ocl{cursor:pointer}.jstree-leaf>.jstree-ocl{cursor:default}.jstree .jstree-open>.jstree-children{display:block}.jstree .jstree-closed>.jstree-children,.jstree .jstree-leaf>.jstree-children{display:none}.jstree-anchor>.jstree-themeicon{margin-right:2px}.jstree-no-icons .jstree-themeicon,.jstree-anchor>.jstree-themeicon-hidden{display:none}.jstree-rtl .jstree-anchor{padding:0 1px 0 4px}.jstree-rtl .jstree-anchor>.jstree-themeicon{margin-left:2px;margin-right:0}.jstree-rtl .jstree-node{margin-left:0}.jstree-rtl .jstree-container-ul>.jstree-node{margin-right:0}.jstree-wholerow-ul{position:relative;display:inline-block;min-width:100%}.jstree-wholerow-ul .jstree-leaf>.jstree-ocl{cursor:pointer}.jstree-wholerow-ul .jstree-anchor,.jstree-wholerow-ul .jstree-icon{position:relative}.jstree-wholerow-ul .jstree-wholerow{width:100%;cursor:pointer;position:absolute;left:0;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.vakata-context{display:none}.vakata-context,.vakata-context ul{margin:0;padding:2px;position:absolute;background:#f5f5f5;border:1px solid #979797;-moz-box-shadow:5px 5px 4px -4px #666;-webkit-box-shadow:2px 2px 2px #999;box-shadow:2px 2px 2px #999}.vakata-context ul{list-style:none;left:100%;margin-top:-2.7em;margin-left:-4px}.vakata-context .vakata-context-right ul{left:auto;right:100%;margin-left:auto;margin-right:-4px}.vakata-context li{list-style:none;display:inline}.vakata-context li>a{display:block;padding:0 2em;text-decoration:none;width:auto;color:#000;white-space:nowrap;line-height:2.4em;-moz-text-shadow:1px 1px 0 #fff;-webkit-text-shadow:1px 1px 0 #fff;text-shadow:1px 1px 0 #fff;-moz-border-radius:1px;-webkit-border-radius:1px;border-radius:1px}.vakata-context li>a:hover{position:relative;background-color:#e8eff7;-moz-box-shadow:0 0 2px #0a6aa1;-webkit-box-shadow:0 0 2px #0a6aa1;box-shadow:0 0 2px #0a6aa1}.vakata-context li>a.vakata-context-parent{background-image:url();background-position:right center;background-repeat:no-repeat}.vakata-context li>a:focus{outline:0}.vakata-context .vakata-context-hover>a{position:relative;background-color:#e8eff7;-moz-box-shadow:0 0 2px #0a6aa1;-webkit-box-shadow:0 0 2px #0a6aa1;box-shadow:0 0 2px #0a6aa1}.vakata-context .vakata-context-separator>a,.vakata-context .vakata-context-separator>a:hover{background:#fff;border:0;border-top:1px solid #e2e3e3;height:1px;min-height:1px;max-height:1px;padding:0;margin:0 0 0 2.4em;border-left:1px solid #e0e0e0;-moz-text-shadow:0 0 0 transparent;-webkit-text-shadow:0 0 0 transparent;text-shadow:0 0 0 transparent;-moz-box-shadow:0 0 0 transparent;-webkit-box-shadow:0 0 0 transparent;box-shadow:0 0 0 transparent;-moz-border-radius:0;-webkit-border-radius:0;border-radius:0}.vakata-context .vakata-contextmenu-disabled a,.vakata-context .vakata-contextmenu-disabled a:hover{color:silver;background-color:transparent;border:0;box-shadow:0 0 0}.vakata-context li>a>i{text-decoration:none;display:inline-block;width:2.4em;height:2.4em;background:0 0;margin:0 0 0 -2em;vertical-align:top;text-align:center;line-height:2.4em}.vakata-context li>a>i:empty{width:2.4em;line-height:2.4em}.vakata-context li>a .vakata-contextmenu-sep{display:inline-block;width:1px;height:2.4em;background:#fff;margin:0 .5em 0 0;border-left:1px solid #e2e3e3}.vakata-context .vakata-contextmenu-shortcut{font-size:.8em;color:silver;opacity:.5;display:none}.vakata-context-rtl ul{left:auto;right:100%;margin-left:auto;margin-right:-4px}.vakata-context-rtl li>a.vakata-context-parent{background-image:url();background-position:left center;background-repeat:no-repeat}.vakata-context-rtl .vakata-context-separator>a{margin:0 2.4em 0 0;border-left:0;border-right:1px solid #e2e3e3}.vakata-context-rtl .vakata-context-left ul{right:auto;left:100%;margin-left:-4px;margin-right:auto}.vakata-context-rtl li>a>i{margin:0 -2em 0 0}.vakata-context-rtl li>a .vakata-contextmenu-sep{margin:0 0 0 .5em;border-left-color:#fff;background:#e2e3e3}#jstree-marker{position:absolute;top:0;left:0;margin:-5px 0 0 0;padding:0;border-right:0;border-top:5px solid transparent;border-bottom:5px solid transparent;border-left:5px solid;width:0;height:0;font-size:0;line-height:0}#jstree-dnd{line-height:16px;margin:0;padding:4px}#jstree-dnd .jstree-icon,#jstree-dnd .jstree-copy{display:inline-block;text-decoration:none;margin:0 2px 0 0;padding:0;width:16px;height:16px}#jstree-dnd .jstree-ok{background:green}#jstree-dnd .jstree-er{background:red}#jstree-dnd .jstree-copy{margin:0 2px}.jstree-proton .jstree-node,.jstree-proton .jstree-icon{background-repeat:no-repeat;background-color:transparent}.jstree-proton .jstree-anchor,.jstree-proton .jstree-wholerow{transition:background-color .15s,box-shadow .15s,color .15s}.jstree-proton .jstree-hovered{background:#76b6ec;color:#fff;border-radius:3px;box-shadow:inset 0 0 1px #76b6ec}.jstree-proton .jstree-clicked{background:#3392e3;color:#fff;border-radius:3px;box-shadow:inset 0 0 1px #3392e3}.jstree-proton .jstree-no-icons .jstree-anchor>.jstree-themeicon{display:none}.jstree-proton .jstree-disabled{background:0 0;color:#666}.jstree-proton .jstree-disabled.jstree-hovered{background:0 0;box-shadow:none}.jstree-proton .jstree-disabled.jstree-clicked{background:#efefef}.jstree-proton .jstree-disabled>.jstree-icon{opacity:.8;filter:url("data:image/svg+xml;utf8,<svg xmlns=\'http://www.w3.org/2000/svg\'><filter id=\'jstree-grayscale\'><feColorMatrix type=\'matrix\' values=\'0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0 0 0 1 0\'/></filter></svg>#jstree-grayscale");-webkit-filter:grayscale(100%)}.jstree-proton .jstree-search{font-style:italic;color:#8b0000;font-weight:700}.jstree-proton .jstree-no-checkboxes .jstree-checkbox{display:none!important}.jstree-proton.jstree-checkbox-no-clicked .jstree-clicked{background:0 0;color:inherit;box-shadow:none}.jstree-proton.jstree-checkbox-no-clicked .jstree-clicked.jstree-hovered{background:#76b6ec;color:#fff}.jstree-proton.jstree-checkbox-no-clicked>.jstree-wholerow-ul .jstree-wholerow-clicked{background:0 0;color:inherit}.jstree-proton.jstree-checkbox-no-clicked>.jstree-wholerow-ul .jstree-wholerow-clicked.jstree-wholerow-hovered{background:#76b6ec;color:#fff}.jstree-proton>.jstree-striped{background:url() left top repeat}.jstree-proton>.jstree-wholerow-ul .jstree-hovered,.jstree-proton>.jstree-wholerow-ul .jstree-clicked{background:0 0;box-shadow:none;border-radius:0}.jstree-proton .jstree-wholerow{-moz-box-sizing:border-box;-webkit-box-sizing:border-box;box-sizing:border-box}.jstree-proton .jstree-wholerow-hovered{background:#76b6ec}.jstree-proton .jstree-wholerow-clicked{background:#3392e3;background:-moz-linear-gradient(top,#3392e3 0,#3392e3 100%);background:-webkit-gradient(linear,left top,left bottom,color-stop(0,#3392e3),color-stop(100%,#3392e3));background:-webkit-linear-gradient(top,#3392e3 0,#3392e3 100%);background:-o-linear-gradient(top,#3392e3 0,#3392e3 100%);background:-ms-linear-gradient(top,#3392e3 0,#3392e3 100%);background:linear-gradient(to bottom,#3392e3 0,#3392e3 100%)}.jstree-proton .jstree-node{min-height:22px;line-height:22px;margin-left:22px;min-width:22px}.jstree-proton .jstree-anchor{line-height:22px;margin:1px 0 2px;height:22px}.jstree-proton .jstree-icon{width:22px;height:22px;line-height:22px}.jstree-proton .jstree-icon:empty{width:22px;height:22px;line-height:22px}.jstree-proton.jstree-rtl .jstree-node{margin-right:22px}.jstree-proton .jstree-wholerow{height:22px}.jstree-proton .jstree-node,.jstree-proton .jstree-icon{background-size:320px 96px;background-image:url(../../node_modules/jstree-bootstrap-theme/dist/themes/proton/32px.png)}.jstree-proton .jstree-node{background-position:-293px -5px;background-repeat:repeat-y}.jstree-proton .jstree-last{background:0 0}.jstree-proton .jstree-open>.jstree-ocl{background-position:-133px -5px}.jstree-proton .jstree-closed>.jstree-ocl{background-position:-101px -5px}.jstree-proton .jstree-leaf>.jstree-ocl{background-position:-69px -5px}.jstree-proton .jstree-themeicon{background-position:-261px -7px}.jstree-proton>.jstree-no-dots .jstree-node,.jstree-proton>.jstree-no-dots .jstree-leaf>.jstree-ocl{background:0 0}.jstree-proton>.jstree-no-dots .jstree-open>.jstree-ocl{background-position:-37px -5px}.jstree-proton>.jstree-no-dots .jstree-closed>.jstree-ocl{background-position:-5px -5px}.jstree-proton .jstree-disabled{background:0 0}.jstree-proton .jstree-disabled.jstree-hovered{background:0 0}.jstree-proton .jstree-disabled.jstree-clicked{background:#efefef}.jstree-proton .jstree-checkbox{background-position:-165px -5px}.jstree-proton .jstree-checkbox:hover{background-position:-165px -37px}.jstree-proton.jstree-checkbox-selection .jstree-clicked>.jstree-checkbox,.jstree-proton .jstree-checked>.jstree-checkbox{background-position:-229px -5px}.jstree-proton.jstree-checkbox-selection .jstree-clicked>.jstree-checkbox:hover,.jstree-proton .jstree-checked>.jstree-checkbox:hover{background-position:-229px -37px}.jstree-proton .jstree-anchor>.jstree-undetermined{background-position:-197px -5px}.jstree-proton .jstree-anchor>.jstree-undetermined:hover{background-position:-197px -37px}.jstree-proton>.jstree-striped{background-size:auto 44px}.jstree-proton.jstree-rtl .jstree-node{background-size:320px 96px;background-image:url();background-position:100% 1px;background-repeat:repeat-y}.jstree-proton.jstree-rtl .jstree-last{background:0 0}.jstree-proton.jstree-rtl .jstree-open>.jstree-ocl{background-position:-133px -37px}.jstree-proton.jstree-rtl .jstree-closed>.jstree-ocl{background-position:-101px -37px}.jstree-proton.jstree-rtl .jstree-leaf>.jstree-ocl{background-position:-69px -37px}.jstree-proton.jstree-rtl>.jstree-no-dots .jstree-node,.jstree-proton.jstree-rtl>.jstree-no-dots .jstree-leaf>.jstree-ocl{background:0 0}.jstree-proton.jstree-rtl>.jstree-no-dots .jstree-open>.jstree-ocl{background-position:-37px -37px}.jstree-proton.jstree-rtl>.jstree-no-dots .jstree-closed>.jstree-ocl{background-position:-5px -37px}.jstree-proton .jstree-themeicon-custom{background-color:transparent;background-size:320px 96px;background-image:none;background-position:0 0}.jstree-proton>.jstree-container-ul .jstree-loading>.jstree-ocl{background:url(../../node_modules/jstree-bootstrap-theme/dist/themes/proton/throbber.gif) center center no-repeat}.jstree-proton .jstree-file{background:url(../../node_modules/jstree-bootstrap-theme/dist/themes/proton/32px.png) -101px -69px no-repeat}.jstree-proton .jstree-folder{background:url(../../node_modules/jstree-bootstrap-theme/dist/themes/proton/32px.png) -261px -5px no-repeat}.jstree-proton>.jstree-container-ul>.jstree-node{margin-left:0;margin-right:0}#jstree-dnd.jstree-proton{line-height:22px;padding:0 4px}#jstree-dnd.jstree-proton .jstree-ok,#jstree-dnd.jstree-proton .jstree-er{background-size:320px 96px;background-image:url(../../node_modules/jstree-bootstrap-theme/dist/themes/proton/32px.png);background-repeat:no-repeat;background-color:transparent}#jstree-dnd.jstree-proton i{background:0 0;width:22px;height:22px;line-height:22px}#jstree-dnd.jstree-proton .jstree-ok{background-position:-5px -69px}#jstree-dnd.jstree-proton .jstree-er{background-position:-37px -69px}.jstree-proton.jstree-rtl .jstree-node{background-image:url()}.jstree-proton.jstree-rtl .jstree-last{background:0 0}.jstree-proton-small .jstree-node{min-height:18px;line-height:18px;margin-left:18px;min-width:18px}.jstree-proton-small .jstree-anchor{line-height:18px;margin:1px 0 2px;height:18px}.jstree-proton-small .jstree-icon{width:18px;height:18px;line-height:18px}.jstree-proton-small .jstree-icon:empty{width:18px;height:18px;line-height:18px}.jstree-proton-small.jstree-rtl .jstree-node{margin-right:18px}.jstree-proton-small .jstree-wholerow{height:18px}.jstree-proton-small .jstree-node,.jstree-proton-small .jstree-icon{background-size:320px 96px;background-image:url(../../node_modules/jstree-bootstrap-theme/dist/themes/proton/32px.png)}.jstree-proton-small .jstree-node{background-position:-295px -7px;background-repeat:repeat-y}.jstree-proton-small .jstree-last{background:0 0}.jstree-proton-small .jstree-open>.jstree-ocl{background-position:-135px -7px}.jstree-proton-small .jstree-closed>.jstree-ocl{background-position:-103px -7px}.jstree-proton-small .jstree-leaf>.jstree-ocl{background-position:-71px -7px}.jstree-proton-small .jstree-themeicon{background-position:-263px -9px}.jstree-proton-small>.jstree-no-dots .jstree-node,.jstree-proton-small>.jstree-no-dots .jstree-leaf>.jstree-ocl{background:0 0}.jstree-proton-small>.jstree-no-dots .jstree-open>.jstree-ocl{background-position:-39px -7px}.jstree-proton-small>.jstree-no-dots .jstree-closed>.jstree-ocl{background-position:-7px -7px}.jstree-proton-small .jstree-disabled{background:0 0}.jstree-proton-small .jstree-disabled.jstree-hovered{background:0 0}.jstree-proton-small .jstree-disabled.jstree-clicked{background:#efefef}.jstree-proton-small .jstree-checkbox{background-position:-167px -7px}.jstree-proton-small .jstree-checkbox:hover{background-position:-167px -39px}.jstree-proton-small.jstree-checkbox-selection .jstree-clicked>.jstree-checkbox,.jstree-proton-small .jstree-checked>.jstree-checkbox{background-position:-231px -7px}.jstree-proton-small.jstree-checkbox-selection .jstree-clicked>.jstree-checkbox:hover,.jstree-proton-small .jstree-checked>.jstree-checkbox:hover{background-position:-231px -39px}.jstree-proton-small .jstree-anchor>.jstree-undetermined{background-position:-199px -7px}.jstree-proton-small .jstree-anchor>.jstree-undetermined:hover{background-position:-199px -39px}.jstree-proton-small>.jstree-striped{background-size:auto 36px}.jstree-proton-small.jstree-rtl .jstree-node{background-size:320px 96px;background-image:url();background-position:100% 1px;background-repeat:repeat-y}.jstree-proton-small.jstree-rtl .jstree-last{background:0 0}.jstree-proton-small.jstree-rtl .jstree-open>.jstree-ocl{background-position:-135px -39px}.jstree-proton-small.jstree-rtl .jstree-closed>.jstree-ocl{background-position:-103px -39px}.jstree-proton-small.jstree-rtl .jstree-leaf>.jstree-ocl{background-position:-71px -39px}.jstree-proton-small.jstree-rtl>.jstree-no-dots .jstree-node,.jstree-proton-small.jstree-rtl>.jstree-no-dots .jstree-leaf>.jstree-ocl{background:0 0}.jstree-proton-small.jstree-rtl>.jstree-no-dots .jstree-open>.jstree-ocl{background-position:-39px -39px}.jstree-proton-small.jstree-rtl>.jstree-no-dots .jstree-closed>.jstree-ocl{background-position:-7px -39px}.jstree-proton-small .jstree-themeicon-custom{background-color:transparent;background-size:320px 96px;background-image:none;background-position:0 0}.jstree-proton-small>.jstree-container-ul .jstree-loading>.jstree-ocl{background:url(../../node_modules/jstree-bootstrap-theme/dist/themes/proton/throbber.gif) center center no-repeat}.jstree-proton-small .jstree-file{background:url(../../node_modules/jstree-bootstrap-theme/dist/themes/proton/32px.png) -103px -71px no-repeat}.jstree-proton-small .jstree-folder{background:url(../../node_modules/jstree-bootstrap-theme/dist/themes/proton/32px.png) -263px -7px no-repeat}.jstree-proton-small>.jstree-container-ul>.jstree-node{margin-left:0;margin-right:0}#jstree-dnd.jstree-proton-small{line-height:18px;padding:0 4px}#jstree-dnd.jstree-proton-small .jstree-ok,#jstree-dnd.jstree-proton-small .jstree-er{background-size:320px 96px;background-image:url(../../node_modules/jstree-bootstrap-theme/dist/themes/proton/32px.png);background-repeat:no-repeat;background-color:transparent}#jstree-dnd.jstree-proton-small i{background:0 0;width:18px;height:18px;line-height:18px}#jstree-dnd.jstree-proton-small .jstree-ok{background-position:-7px -71px}#jstree-dnd.jstree-proton-small .jstree-er{background-position:-39px -71px}.jstree-proton-small.jstree-rtl .jstree-node{background-image:url()}.jstree-proton-small.jstree-rtl .jstree-last{background:0 0}.jstree-proton-large .jstree-node{min-height:32px;line-height:32px;margin-left:32px;min-width:32px}.jstree-proton-large .jstree-anchor{line-height:32px;margin:1px 0 2px;height:32px}.jstree-proton-large .jstree-icon{width:32px;height:32px;line-height:32px}.jstree-proton-large .jstree-icon:empty{width:32px;height:32px;line-height:32px}.jstree-proton-large.jstree-rtl .jstree-node{margin-right:32px}.jstree-proton-large .jstree-wholerow{height:32px}.jstree-proton-large .jstree-node,.jstree-proton-large .jstree-icon{background-size:320px 96px;background-image:url(../../node_modules/jstree-bootstrap-theme/dist/themes/proton/32px.png)}.jstree-proton-large .jstree-node{background-position:-288px 0;background-repeat:repeat-y}.jstree-proton-large .jstree-last{background:0 0}.jstree-proton-large .jstree-open>.jstree-ocl{background-position:-128px 0}.jstree-proton-large .jstree-closed>.jstree-ocl{background-position:-96px 0}.jstree-proton-large .jstree-leaf>.jstree-ocl{background-position:-64px 0}.jstree-proton-large .jstree-themeicon{background-position:-256px -2px}.jstree-proton-large>.jstree-no-dots .jstree-node,.jstree-proton-large>.jstree-no-dots .jstree-leaf>.jstree-ocl{background:0 0}.jstree-proton-large>.jstree-no-dots .jstree-open>.jstree-ocl{background-position:-32px 0}.jstree-proton-large>.jstree-no-dots .jstree-closed>.jstree-ocl{background-position:0 0}.jstree-proton-large .jstree-disabled{background:0 0}.jstree-proton-large .jstree-disabled.jstree-hovered{background:0 0}.jstree-proton-large .jstree-disabled.jstree-clicked{background:#efefef}.jstree-proton-large .jstree-checkbox{background-position:-160px 0}.jstree-proton-large .jstree-checkbox:hover{background-position:-160px -32px}.jstree-proton-large.jstree-checkbox-selection .jstree-clicked>.jstree-checkbox,.jstree-proton-large .jstree-checked>.jstree-checkbox{background-position:-224px 0}.jstree-proton-large.jstree-checkbox-selection .jstree-clicked>.jstree-checkbox:hover,.jstree-proton-large .jstree-checked>.jstree-checkbox:hover{background-position:-224px -32px}.jstree-proton-large .jstree-anchor>.jstree-undetermined{background-position:-192px 0}.jstree-proton-large .jstree-anchor>.jstree-undetermined:hover{background-position:-192px -32px}.jstree-proton-large>.jstree-striped{background-size:auto 64px}.jstree-proton-large.jstree-rtl .jstree-node{background-size:320px 96px;background-image:url();background-position:100% 1px;background-repeat:repeat-y}.jstree-proton-large.jstree-rtl .jstree-last{background:0 0}.jstree-proton-large.jstree-rtl .jstree-open>.jstree-ocl{background-position:-128px -32px}.jstree-proton-large.jstree-rtl .jstree-closed>.jstree-ocl{background-position:-96px -32px}.jstree-proton-large.jstree-rtl .jstree-leaf>.jstree-ocl{background-position:-64px -32px}.jstree-proton-large.jstree-rtl>.jstree-no-dots .jstree-node,.jstree-proton-large.jstree-rtl>.jstree-no-dots .jstree-leaf>.jstree-ocl{background:0 0}.jstree-proton-large.jstree-rtl>.jstree-no-dots .jstree-open>.jstree-ocl{background-position:-32px -32px}.jstree-proton-large.jstree-rtl>.jstree-no-dots .jstree-closed>.jstree-ocl{background-position:0 -32px}.jstree-proton-large .jstree-themeicon-custom{background-color:transparent;background-size:320px 96px;background-image:none;background-position:0 0}.jstree-proton-large>.jstree-container-ul .jstree-loading>.jstree-ocl{background:url(../../node_modules/jstree-bootstrap-theme/dist/themes/proton/throbber.gif) center center no-repeat}.jstree-proton-large .jstree-file{background:url(../../node_modules/jstree-bootstrap-theme/dist/themes/proton/32px.png) -96px -64px no-repeat}.jstree-proton-large .jstree-folder{background:url(../../node_modules/jstree-bootstrap-theme/dist/themes/proton/32px.png) -256px 0 no-repeat}.jstree-proton-large>.jstree-container-ul>.jstree-node{margin-left:0;margin-right:0}#jstree-dnd.jstree-proton-large{line-height:32px;padding:0 4px}#jstree-dnd.jstree-proton-large .jstree-ok,#jstree-dnd.jstree-proton-large .jstree-er{background-size:320px 96px;background-image:url(../../node_modules/jstree-bootstrap-theme/dist/themes/proton/32px.png);background-repeat:no-repeat;background-color:transparent}#jstree-dnd.jstree-proton-large i{background:0 0;width:32px;height:32px;line-height:32px}#jstree-dnd.jstree-proton-large .jstree-ok{background-position:0 -64px}#jstree-dnd.jstree-proton-large .jstree-er{background-position:-32px -64px}.jstree-proton-large.jstree-rtl .jstree-node{background-image:url()}.jstree-proton-large.jstree-rtl .jstree-last{background:0 0}@media (max-width:768px){#jstree-dnd.jstree-dnd-responsive{line-height:30px;font-weight:700;font-size:1.1em;text-shadow:1px 1px #fff}#jstree-dnd.jstree-dnd-responsive>i{background:0 0;width:30px;height:30px}#jstree-dnd.jstree-dnd-responsive>.jstree-ok{background-image:url(../../node_modules/jstree-bootstrap-theme/dist/themes/proton/30px.png);background-position:0 -150px;background-size:90px 180px}#jstree-dnd.jstree-dnd-responsive>.jstree-er{background-image:url(../../node_modules/jstree-bootstrap-theme/dist/themes/proton/30px.png);background-position:-30px -150px;background-size:90px 180px}#jstree-marker.jstree-dnd-responsive{border-left-width:10px;border-top-width:10px;border-bottom-width:10px;margin-top:-10px}}@media (max-width:768px){.jstree-proton-responsive .jstree-container-ul{overflow:hidden}.jstree-proton-responsive .jstree-icon{background-image:url(../../node_modules/jstree-bootstrap-theme/dist/themes/proton/30px.png);background-size:90px 180px}.jstree-proton-responsive .jstree-node,.jstree-proton-responsive .jstree-leaf>.jstree-ocl{background:0 0}.jstree-proton-responsive .jstree-node{min-height:30px;line-height:30px;margin-left:30px;min-width:30px;white-space:nowrap}.jstree-proton-responsive .jstree-anchor{line-height:38px;height:38px;margin:0}.jstree-proton-responsive .jstree-icon,.jstree-proton-responsive .jstree-icon:empty{margin-top:4px;width:30px;height:30px;line-height:30px}.jstree-proton-responsive>.jstree-container-ul>.jstree-node{margin-left:0}.jstree-proton-responsive.jstree-rtl .jstree-node{margin-left:0;margin-right:30px}.jstree-proton-responsive.jstree-rtl .jstree-container-ul>.jstree-node{margin-right:0}.jstree-proton-responsive .jstree-ocl,.jstree-proton-responsive .jstree-themeicon,.jstree-proton-responsive .jstree-checkbox{background-size:90px 180px}.jstree-proton-responsive .jstree-leaf>.jstree-ocl{background:0 0}.jstree-proton-responsive .jstree-open>.jstree-ocl{background-position:0 0!important}.jstree-proton-responsive .jstree-closed>.jstree-ocl{background-position:0 -30px!important}.jstree-proton-responsive.jstree-rtl .jstree-closed>.jstree-ocl{background-position:-30px 0!important}.jstree-proton-responsive .jstree-themeicon{background-position:-30px -30px}.jstree-proton-responsive .jstree-checkbox,.jstree-proton-responsive .jstree-checkbox:hover{background-position:-30px -60px}.jstree-proton-responsive.jstree-checkbox-selection .jstree-clicked>.jstree-checkbox,.jstree-proton-responsive.jstree-checkbox-selection .jstree-clicked>.jstree-checkbox:hover,.jstree-proton-responsive .jstree-checked>.jstree-checkbox,.jstree-proton-responsive .jstree-checked>.jstree-checkbox:hover{background-position:0 -60px}.jstree-proton-responsive .jstree-anchor>.jstree-undetermined,.jstree-proton-responsive .jstree-anchor>.jstree-undetermined:hover{background-position:0 -90px}.jstree-proton-responsive>.jstree-striped{background:0 0}.jstree-proton-responsive .jstree-wholerow-ul li{position:relative}.jstree-proton-responsive .jstree-wholerow-ul .jstree-wholerow{position:absolute;top:0;left:-1000px;right:-1000px;width:auto;height:100%}.jstree-proton-responsive .jstree-wholerow{border-top:1px solid rgba(0,0,0,.05);background:rgba(0,0,0,.02);height:30px}.jstree-proton-responsive .jstree-wholerow-hovered{background:#76b6ec}.jstree-proton-responsive .jstree-wholerow-clicked{background:#3392e3}.jstree-proton-responsive .jstree-children .jstree-open+.jstree-open{box-shadow:none}.jstree-proton-responsive .jstree-node,.jstree-proton-responsive .jstree-icon,.jstree-proton-responsive .jstree-node>.jstree-ocl,.jstree-proton-responsive .jstree-themeicon,.jstree-proton-responsive .jstree-checkbox{background-image:url(../../node_modules/jstree-bootstrap-theme/dist/themes/proton/30px.png);background-size:90px 180px}.jstree-proton-responsive .jstree-node{background-position:-60px 0;background-repeat:repeat-y}.jstree-proton-responsive .jstree-last{background:0 0}.jstree-proton-responsive .jstree-leaf>.jstree-ocl{background-position:-30px -90px}.jstree-proton-responsive .jstree-last>.jstree-ocl{background-position:-30px -120px}.jstree-proton-responsive .jstree-themeicon-custom{background-color:transparent;background-image:none;background-position:0 0}.jstree-proton-responsive .jstree-file{background:url(../../node_modules/jstree-bootstrap-theme/dist/themes/proton/30px.png) 0 -120px no-repeat;background-size:90px 180px}.jstree-proton-responsive .jstree-folder{background:url(../../node_modules/jstree-bootstrap-theme/dist/themes/proton/30px.png) -30px -30px no-repeat;background-size:90px 180px}.jstree-proton-responsive>.jstree-container-ul>.jstree-node{margin-left:0;margin-right:0}}@font-face{font-family:'Titillium Web';src:url(fonts/titillium/titilliumweb-extralight-webfont.eot);src:url(fonts/titillium/titilliumweb-extralight-webfont.eot?#iefix) format('embedded-opentype'),url(fonts/titillium/titilliumweb-extralight-webfont.woff) format('woff'),url(fonts/titillium/titilliumweb-extralight-webfont.ttf) format('truetype'),url(fonts/titillium/titilliumweb-extralight-webfont.svg#titillium_webthin) format('svg');font-weight:300;font-style:normal}@font-face{font-family:'Titillium Web';src:url(fonts/titillium/titilliumweb-regular-webfont.eot);src:url(fonts/titillium/titilliumweb-regular-webfont.eot?#iefix) format('embedded-opentype'),url(fonts/titillium/titilliumweb-regular-webfont.woff) format('woff'),url(fonts/titillium/titilliumweb-regular-webfont.ttf) format('truetype'),url(fonts/titillium/titilliumweb-regular-webfont.svg#titillium_webregular) format('svg');font-weight:400;font-style:normal}@font-face{font-family:'Titillium Web';src:url(fonts/titillium/titilliumweb-bold-webfont.eot);src:url(fonts/titillium/titilliumweb-bold-webfont.eot?#iefix) format('embedded-opentype'),url(fonts/titillium/titilliumweb-bold-webfont.woff) format('woff'),url(fonts/titillium/titilliumweb-bold-webfont.ttf) format('truetype'),url(fonts/titillium/titilliumweb-bold-webfont.svg#titillium_webbold) format('svg');font-weight:700;font-style:normal}@media screen and (-webkit-min-device-pixel-ratio:0){@font-face{font-family:'Titillium Web';src:url(fonts/titillium/titilliumweb-extralight-webfont.svg#titillium_webthin) format('svg');font-weight:300;font-style:normal}@font-face{font-family:'Titillium Web';src:url(fonts/titillium/titilliumweb-regular-webfont.svg#titillium_webregular) format('svg');font-weight:400;font-style:normal}@font-face{font-family:'Titillium Web';src:url(fonts/titillium/titilliumweb-bold-webfont.svg#titillium_webbold) format('svg');font-weight:700;font-style:normal}}.jstree-proton{font-family:'Titillium Web',sans-serif,Arial,sans-serif} \ No newline at end of file diff --git a/apps/maarch_entreprise/css/status-administration.component.css b/apps/maarch_entreprise/css/status-administration.component.css index facab33b3c05298b78b7ce983d755dc210423792..e69de29bb2d1d6434b8b29ae775ad8c2e48c5391 100755 --- a/apps/maarch_entreprise/css/status-administration.component.css +++ b/apps/maarch_entreprise/css/status-administration.component.css @@ -1,25 +0,0 @@ - -#statusIconList i{ - color : #666; - font-size: 18px; -} -#statusIconList button{ - width: 60px; - margin-bottom: 5px; -} -#statusIconList .btn-primary i{ - color:white; -} -.mandatory{ - font-size:7px; - color:red; - top: -1.5em; -} - -label{ - font-weight: normal; -} - -.ng-invalid:not(form) { - border-left: 5px solid #a94442; -} diff --git a/apps/maarch_entreprise/css/user-administration.component.css b/apps/maarch_entreprise/css/user-administration.component.css index d9e1defd75b1e6704e04e2db18445aa22415715e..3d31b32e00f37767ab723b6266095df81e318258 100755 --- a/apps/maarch_entreprise/css/user-administration.component.css +++ b/apps/maarch_entreprise/css/user-administration.component.css @@ -1,100 +1,27 @@ -h2{ - background-color: #009DC5 !important; - color: white !important; - margin-top: -10px !important; - margin-left: -10px !important; - margin-right: -10px !important; - padding: 10px !important; - font-size: 16px !important; +.groupOtherInfo input{ + opacity: 0.5; } -.btn-default:focus.label-primary ,.btn-default:hover.label-primary ,.btn-default.active.label-primary, .btn-default:active.label-primary, .open > .dropdown-toggle.btn-default.label-primary{ - background: #337ab7 !important; +#basketList li{ + font-size: 10px; } -.userAdministrationClickable li { - cursor: pointer; -} - -.ng-invalid:not(form) { - border-left: 5px solid #a94442; -} - -.modal-content{ - background-color: #009DC5 !important; -} -.modal-header h4{ - color: white !important; +#basketList li:before { + /*Using a Bootstrap glyphicon as the bullet point*/ + content: "\f01c"; + font-family: 'FontAwesome'; + font-size: 9px; + margin-right: 5px; } -.modal-body{ - background-color: white; - padding:10px; -} -.modal-body .list-group li{ - /*border-color: #009DC5 !important;*/ - font-weight: bold; -} - -.modal-footer{ - background:white; -} -/* layout.css Style */ -.upload-drop-zone { - font-size: 16px; - height: 100px; - border-width: 2px; - margin-bottom: 20px; +.avatar { + width: 60px; + height: 60px; + display: block; + margin-right: 15px; } -/* skin.css Style*/ -.upload-drop-zone { - color: #ccc; - border-style: dashed; - border-color: #ccc; - line-height: 100px; - text-align: center -} -.upload-drop-zone.drop { - color: #222; - border-color: #222; -} -/* Alert info*/ -#resultInfo{ - top :10px; - text-align: center; - position: absolute; - width: 30%; - right: 10px; - z-index: 1051; - height: 40px; - -moz-box-shadow: 0px 0px 5px 0px #656565; - -webkit-box-shadow: 0px 0px 5px 0px #656565; - -o-box-shadow: 0px 0px 5px 0px #656565; - box-shadow: 0px 0px 5px 0px #656565; - filter:progid:DXImageTransform.Microsoft.Shadow(color=#656565, Direction=NaN, Strength=5); -} -#signList { - overflow-x:scroll; - overflow-y:hidden; - white-space:nowrap; - margin-right: 0px !important; - margin-left: 0px !important; -} -#signList [class*="col-lg"], #signList [class*="col-md"], #signList [class*="col-sm"] { - float:none; - display:inline-block; - white-space:normal; - vertical-align:top; -} -.caption p{ - white-space: nowrap; - overflow: hidden; -} -.form-control.btn-success[disabled]{ - background-color: #5cb85c; -} -.form-control.btn-primary[disabled]{ - background-color: #286090; -} +.panel-footer /deep/ .mat-input-wrapper{ + margin-bottom:-20px !important; +} \ No newline at end of file diff --git a/apps/maarch_entreprise/css/users-administration.component.css b/apps/maarch_entreprise/css/users-administration.component.css index 48e517f541c284015e1469bb0d3a68a43f3412ae..d430e1d2ccdb891c75682a1e29271dfdc0903766 100755 --- a/apps/maarch_entreprise/css/users-administration.component.css +++ b/apps/maarch_entreprise/css/users-administration.component.css @@ -1,3 +1,4 @@ + button:disabled{ opacity:0.3 !important; } \ No newline at end of file diff --git a/apps/maarch_entreprise/documents_list_with_attachments.php b/apps/maarch_entreprise/documents_list_with_attachments.php index 3bcf78c47146a117d511bc3aab5e0a6e8cd92ec9..caa1d47fd195fdaf2cec8b2fc4ea041222fbe102 100755 --- a/apps/maarch_entreprise/documents_list_with_attachments.php +++ b/apps/maarch_entreprise/documents_list_with_attachments.php @@ -89,7 +89,7 @@ array_push( "contact_firstname", "contact_lastname", "contact_society", "user_lastname", "user_firstname", "priority", "creation_date", "admission_date", "subject", "process_limit_date", "entity_label", "dest_user", "category_id", "type_label", - "exp_user_id", "count_attachment", "alt_identifier", "is_multicontacts", "locker_user_id", "locker_time", "address_id" + "exp_user_id", "count_attachment", "alt_identifier", "is_multicontacts", "locker_user_id", "locker_time", "address_id", "filename" ); if ($core_tools->is_module_loaded("cases") == true) { diff --git a/apps/maarch_entreprise/indexing_searching/change_category_actions.php b/apps/maarch_entreprise/indexing_searching/change_category_actions.php index 4ba0179fa4ea7a81deee67ddcf8ac627d4841b43..3976db13a9388f666d92f50b9dcfbc471073c16f 100755 --- a/apps/maarch_entreprise/indexing_searching/change_category_actions.php +++ b/apps/maarch_entreprise/indexing_searching/change_category_actions.php @@ -7,7 +7,7 @@ $b = new basket(); $_SESSION['category_id'] = $_REQUEST['category_id']; $actions = $b->get_actions_from_current_basket( - $_REQUEST['resId'], $_REQUEST['collId'], 'PAGE_USE', false + $_REQUEST['resId'], $_REQUEST['collId'], 'PAGE_USE', true ); if (count($actions) > 0) { //$frmStr .= '<b>' . _ACTIONS . ' : </b>'; diff --git a/apps/maarch_entreprise/indexing_searching/details.php b/apps/maarch_entreprise/indexing_searching/details.php index 43c7ae4fae2d4979007de4097592721d347f6f17..5db8b2b91ed52aeb2df593da42819433da728484 100755 --- a/apps/maarch_entreprise/indexing_searching/details.php +++ b/apps/maarch_entreprise/indexing_searching/details.php @@ -557,7 +557,7 @@ if ((!empty($_SESSION['error']) && ! ($_SESSION['indexation'] )) ) ?> <?php $detailsExport .= "<h1><center>"._DETAILS_PRINT." : ".$s_id."</center></h1><hr>";?> - <div class="fa fa-tachometer detailsTab DetailsTabFunc TabSelected " id="DetailstachometerTab" style="font-size:2em;padding-left: 15px;<?php if(strpos($_SERVER['HTTP_USER_AGENT'], 'Chrome')){echo 'padding-right: 0px;';}else{echo 'padding-right: 15px;';}?>" title="<?php echo _PROPERTIES;?>" onclick="tabClicked('DetailstachometerTab',false);"> + <div class="fa fa-info-circle detailsTab DetailsTabFunc TabSelected " id="DetailstachometerTab" style="font-size:2em;padding-left: 15px;<?php if(strpos($_SERVER['HTTP_USER_AGENT'], 'Chrome')){echo 'padding-right: 0px;';}else{echo 'padding-right: 15px;';}?>" title="<?php echo _PROPERTIES;?>" onclick="tabClicked('DetailstachometerTab',false);"> <sup><span style="font-size: 10px;<?php echo $style; ?>" class="nbResZero">0</span></sup></div> @@ -568,7 +568,7 @@ if ((!empty($_SESSION['error']) && ! ($_SESSION['indexation'] )) ) $pathScriptTab = 'index.php?display=true&page=show_technicalInfo_tab'; $uniqueString .= '<div class="fa fa-cogs DetailsTabFunc" id="DetailsCogdTab" style="font-size:2em;padding-left: 15px;padding-right: 15px;" title="'._TECHNICAL_INFORMATIONS.'" onclick="loadSpecificTab(\'uniqueDetailsIframe\',\''.$pathScriptTab.'\');tabClicked(\'DetailsCogdTab\',true);"><sup><span style="font-size: 10px;display: none;" class="nbResZero"></span></sup></div>'; } - $uniqueString .= '<div class="fa fa-gear DetailsTabFunc" id="DetailsGearTab" " style="font-size:2em;padding-left: 15px;'; + $uniqueString .= '<div class="fa fa-share-alt DetailsTabFunc" id="DetailsGearTab" " style="font-size:2em;padding-left: 15px;'; if(strpos($_SERVER['HTTP_USER_AGENT'], 'Chrome')) { $uniqueString .= 'padding-right: 0px;'; }else { @@ -616,7 +616,7 @@ if ((!empty($_SESSION['error']) && ! ($_SESSION['indexation'] )) ) if ($core->is_module_loaded('visa')) { $pathScriptTab = 'index.php?display=true&page=show_visa_tab&module=visa&resId='.$s_id.'&collId='.$coll_id.'&destination='.$destination.'&fromDetail=true'; - $uniqueString .= '<div id="visa_tab" class="fa fa-certificate DetailsTabFunc " style="font-size:2em;padding-left: 15px;'; + $uniqueString .= '<div id="visa_tab" class="fa fa-retweet DetailsTabFunc " style="font-size:2em;padding-left: 15px;'; $uniqueString .='padding-right: 15px;" title="'._VISA_WORKFLOW.'" onclick="loadSpecificTab(\'uniqueDetailsIframe\',\''.$pathScriptTab.'\');tabClicked(\'visa_tab\',true);"> <sup id="visa_tab_badge"></sup></div>'; //LOAD TOOLBAR BADGE $toolbarBagde_script = 'index.php?display=true&module=visa&page=load_toolbar_visa&resId='.$s_id.'&collId='.$coll_id; @@ -625,7 +625,7 @@ if ((!empty($_SESSION['error']) && ! ($_SESSION['indexation'] )) ) if ($core->is_module_loaded('avis')) { $pathScriptTab = 'index.php?display=true&page=show_avis_tab&module=avis&resId='.$s_id.'&collId='.$coll_id.'&fromDetail=true'; - $uniqueString .= '<div id="avis_tab" class="fa fa-check-square DetailsTabFunc " style="font-size:2em;padding-left: 15px;'; + $uniqueString .= '<div id="avis_tab" class="fa fa-commenting-o DetailsTabFunc " style="font-size:2em;padding-left: 15px;'; $uniqueString .= 'padding-right: 15px;" title="'._AVIS_WORKFLOW.'" onclick="loadSpecificTab(\'uniqueDetailsIframe\',\''.$pathScriptTab.'\');tabClicked(\'avis_tab\',true);"> <sup id="avis_tab_badge"></sup></div><div id="page_circuit_avis" style="overflow-x: hidden;">'; $uniqueString .= '</div>'; @@ -658,7 +658,7 @@ if ((!empty($_SESSION['error']) && ! ($_SESSION['indexation'] )) ) $pathScriptTab = 'index.php?display=true&page=show_history_tab&resId=' . $s_id . '&collId=' . $coll_id; - $uniqueString .= '<div class="fa fa-line-chart DetailsTabFunc" id="DetailsLineChartTab" style="font-size:2em;padding-left: 15px;'; + $uniqueString .= '<div class="fa fa-history DetailsTabFunc" id="DetailsLineChartTab" style="font-size:2em;padding-left: 15px;'; if(strpos($_SERVER['HTTP_USER_AGENT'], 'Chrome')) { $uniqueString .= 'padding-right: 0px;'; } else { @@ -677,7 +677,7 @@ if ((!empty($_SESSION['error']) && ! ($_SESSION['indexation'] )) ) // $note = ''; $pathScriptTab = 'index.php?display=true&module=notes&page=notes&identifier=' . $s_id . '&origin=document&coll_id=' . $coll_id . '&load&size=full'; - $uniqueString .= '<div id="notes_tab" class="fa fa-pencil DetailsTabFunc" style="font-size:2em;padding-left: 15px;padding-right: 15px;" title="'. _NOTES.'" onclick="loadSpecificTab(\'uniqueDetailsIframe\',\''.$pathScriptTab.'\');;tabClicked(\'notes_tab\',true);"> <sup id="notes_tab_badge"></sup></div>'; + $uniqueString .= '<div id="notes_tab" class="fa fa-sticky-note DetailsTabFunc" style="font-size:2em;padding-left: 15px;padding-right: 15px;" title="'. _NOTES.'" onclick="loadSpecificTab(\'uniqueDetailsIframe\',\''.$pathScriptTab.'\');;tabClicked(\'notes_tab\',true);"> <sup id="notes_tab_badge"></sup></div>'; //LOAD TOOLBAR BADGE $toolbarBagde_script = 'index.php?display=true&module=notes&page=load_toolbar_notes&resId='.$s_id.'&collId='.$coll_id; $uniqueString .='<script>loadToolbarBadge(\'notes_tab\',\''.$toolbarBagde_script.'\');</script>'; @@ -1168,7 +1168,7 @@ if ((!empty($_SESSION['error']) && ! ($_SESSION['indexation'] )) ) if ($indexes[$key]['type_field'] == 'input') { ?> - <input type="text" name="<?php functions::xecho($key);?>" id="<?php functions::xecho($key);?>" value="<?php functions::xecho($indexes[$key]['show_value']);?>" <?php if (!isset($indexes[$key]['readonly']) || $indexes[$key]['readonly'] == true){ echo 'readonly="readonly" class="readonly"';}else if ($indexes[$key]['type'] == 'date'){echo 'onclick="showCalender(this);"';}?> size="40" title="<?php functions::xecho($indexes[$key]['show_value']);?>" alt="<?php functions::xecho($indexes[$key]['show_value']);?>" /> + <textarea name="<?php functions::xecho($key);?>" id="<?php functions::xecho($key);?>" value="<?php functions::xecho($indexes[$key]['show_value']);?>" <?php if (!isset($indexes[$key]['readonly']) || $indexes[$key]['readonly'] == true){ echo 'readonly="readonly" class="readonly"';}else if ($indexes[$key]['type'] == 'date'){echo 'onclick="showCalender(this);"';}?> style="width: 200px; " title="<?php functions::xecho($indexes[$key]['show_value']);?>" alt="<?php functions::xecho($indexes[$key]['show_value']);?>" ></textarea> <?php } else diff --git a/apps/maarch_entreprise/indexing_searching/documents_list_mlb_search_adv.php b/apps/maarch_entreprise/indexing_searching/documents_list_mlb_search_adv.php index 92d232fddd33b3d09bc97c8c2635c2d6bc07da0f..6f799347e5880f0a9082a9288674b9242c3595f6 100755 --- a/apps/maarch_entreprise/indexing_searching/documents_list_mlb_search_adv.php +++ b/apps/maarch_entreprise/indexing_searching/documents_list_mlb_search_adv.php @@ -229,12 +229,11 @@ if($mode == 'normal') { array_push($select[$view], "res_id", "res_id as is_labeled", "alt_identifier", "priority", "status", "subject", "category_id as category_img", "contact_firstname", "contact_lastname", "contact_society", "user_lastname", "user_firstname", "category_id", "dest_user", "type_label", - "creation_date", "entity_label", "address_id", "exp_user_id", "count_attachment", "is_multicontacts"); + "creation_date", "entity_label", "address_id", "exp_user_id", "count_attachment", "is_multicontacts","filename"); //Cases if($core_tools->is_module_loaded("cases") == true) { array_push($select[$view], "case_id", "case_label", "case_description"); } - //Folder if ($core_tools->is_module_loaded("folder")) { array_push($select[$view], "folders_system_id", "folder_name"); @@ -769,7 +768,7 @@ if($mode == 'normal') { $tab[$i][$j]["value_export"] = $tab[$i][$j]['value']; $tab[$i][$j]["value"] = $contact->get_contact_information_from_view($_SESSION['mlb_search_current_category_id'], $contact_lastname, $contact_firstname, $contact_society, $user_lastname, $user_firstname); $tab[$i][$j]["order"]=false; - } + } } } diff --git a/apps/maarch_entreprise/indexing_searching/search_adv.php b/apps/maarch_entreprise/indexing_searching/search_adv.php index ea16b4dd98d87b48cb801f2372fb8a6bdd9d885e..f586bfb30a62c600818c690f5c3ba8218f6d31c7 100755 --- a/apps/maarch_entreprise/indexing_searching/search_adv.php +++ b/apps/maarch_entreprise/indexing_searching/search_adv.php @@ -336,7 +336,19 @@ if($core_tools->is_module_loaded('entities')) } $param['destination_mu'] = array('label' => _DESTINATION_SEARCH, 'type' => 'select_multiple', 'param' => array('field_label' => _DESTINATION_SEARCH, 'label_title' => _CHOOSE_ENTITES_SEARCH_TITLE, -'id' => 'services','options' => $arr_tmp)); + 'id' => 'services','options' => $arr_tmp)); + + $stmt = $conn->query("SELECT DISTINCT ".$table.".initiator, e.short_label FROM ".$table." join ".$_SESSION['tablename']['ent_entities']." e on e.entity_id = ".$table.".initiator + ".$where." group by e.short_label, ".$table.".initiator order by e.short_label"); + //Initiator + $arr_tmp = array(); + while($res = $stmt->fetchObject()) + { + array_push($arr_tmp, array('VALUE' => $res->initiator, 'LABEL' => $res->short_label)); + } + + $param['initiator_mu'] = array('label' => _INITIATORS, 'type' => 'select_multiple', 'param' => array('field_label' => _INITIATORS, 'label_title' => _CHOOSE_ENTITES_SEARCH_TITLE, + 'id' => 'initiatorServices','options' => $arr_tmp)); } diff --git a/apps/maarch_entreprise/indexing_searching/search_adv_result.php b/apps/maarch_entreprise/indexing_searching/search_adv_result.php index 839887123f9a9bd65f11f1962ec56eb550624add..53a75168424fbc8035280cd63955121fe7891cd4 100755 --- a/apps/maarch_entreprise/indexing_searching/search_adv_result.php +++ b/apps/maarch_entreprise/indexing_searching/search_adv_result.php @@ -111,6 +111,7 @@ if (count($_REQUEST['meta']) > 0) { //$func->show_array($tab_id_fields); for ($j=0; $j<count($tab_id_fields);$j++) { // ENTITIES + if ($tab_id_fields[$j] == 'services_chosen' && isset($_REQUEST['services_chosen'])) { $json_txt .= " 'services_chosen' : ["; @@ -119,12 +120,24 @@ if (count($_REQUEST['meta']) > 0) { $json_txt .= "'".$_REQUEST['services_chosen'][$get_i]."',"; } $json_txt = substr($json_txt, 0, -1); - $where_request .= " destination IN (:serviceChosen) "; $where_request .=" and "; $arrayPDO = array_merge($arrayPDO, array(":serviceChosen" => $_REQUEST['services_chosen'])); $json_txt .= '],'; - } elseif ($tab_id_fields[$j] == 'multifield' && !empty($_REQUEST['multifield'])) { + } + elseif ($tab_id_fields[$j] == 'initiatorServices_chosen' && isset($_REQUEST['initiatorServices_chosen'])) { + $json_txt .= " 'initiatorServices_chosen' : ["; + + for ($get_i = 0; $get_i <count($_REQUEST['initiatorServices_chosen']); $get_i++) { + $json_txt .= "'".$_REQUEST['initiatorServices_chosen'][$get_i]."',"; + } + $json_txt = substr($json_txt, 0, -1); + $where_request .= " initiator IN (:initiatorServiceChosen) "; + $where_request .=" and "; + $arrayPDO = array_merge($arrayPDO, array(":initiatorServiceChosen" => $_REQUEST['initiatorServices_chosen'])); + $json_txt .= '],'; + } + elseif ($tab_id_fields[$j] == 'multifield' && !empty($_REQUEST['multifield'])) { // MULTIFIELD : subject, title, doc_custom_t1, process notes $json_txt .= "'multifield' : ['".addslashes(trim($_REQUEST['multifield']))."'],"; $where_request .= "(lower(translate(subject,'ÀÃÂÃÄÅÆÇÈÉÊËÌÃÃŽÃÃÑÒÓÔÕÖØÙÚÛÜÃÞßà áâãäåæçèéêëìÃîïðñòóôõöøùúûýýþÿŔŕ','aaaaaaaceeeeiiiidnoooooouuuuybsaaaaaaaceeeeiiiidnoooooouuuyybyRr')) like lower(:multifield) " diff --git a/apps/maarch_entreprise/js/angular/app/administration/action-administration.component.js b/apps/maarch_entreprise/js/angular/app/administration/action-administration.component.js index f3e025c30ff6beeac49c10d37ee0ab5c06bc82d6..7a9751a5881f5ed156202d640249fcde1251783d 100755 --- a/apps/maarch_entreprise/js/angular/app/administration/action-administration.component.js +++ b/apps/maarch_entreprise/js/angular/app/administration/action-administration.component.js @@ -12,24 +12,32 @@ Object.defineProperty(exports, "__esModule", { value: true }); var core_1 = require("@angular/core"); var http_1 = require("@angular/common/http"); var router_1 = require("@angular/router"); +var translate_component_1 = require("../translate.component"); +var notification_service_1 = require("../notification.service"); var ActionAdministrationComponent = (function () { - function ActionAdministrationComponent(http, route, router) { + function ActionAdministrationComponent(http, route, router, notify) { this.http = http; this.route = route; this.router = router; - this.mode = null; + this.notify = notify; + this.lang = translate_component_1.LANG; + this._search = ''; this.action = {}; this.statusList = []; this.actionPagesList = []; - this.lang = {}; this.categoriesList = []; this.keywordsList = []; this.loading = false; } ActionAdministrationComponent.prototype.updateBreadcrumb = function (applicationName) { - if ($j('#ariane')[0]) { - $j('#ariane')[0].innerHTML = "<a href='index.php?reinit=true'>" + applicationName + "</a> > <a onclick='location.hash = \"/administration\"' style='cursor: pointer'>Administration</a> > <a onclick='location.hash = \"/administration/actions\"' style='cursor: pointer'>Actions</a> > Modification"; + var breadCrumb = "<a href='index.php?reinit=true'>" + applicationName + "</a> > <a onclick='location.hash = \"/administration\"' style='cursor: pointer'>" + this.lang.administration + "</a> > <a onclick='location.hash = \"/administration/actions\"' style='cursor: pointer'>" + this.lang.actions + "</a> > "; + if (this.creationMode == true) { + breadCrumb += this.lang.actionCreation; } + else { + breadCrumb += this.lang.actionModification; + } + $j('#ariane')[0].innerHTML = breadCrumb; }; ActionAdministrationComponent.prototype.prepareActions = function () { $j('#inner_content').remove(); @@ -42,84 +50,63 @@ var ActionAdministrationComponent = (function () { this.updateBreadcrumb(angularGlobals.applicationName); this.route.params.subscribe(function (params) { if (typeof params['id'] == "undefined") { - _this.mode = 'create'; + _this.creationMode = true; _this.http.get(_this.coreUrl + 'rest/initAction') .subscribe(function (data) { _this.action = data.action; - _this.lang = data.lang; - _this.lang.pageTitle = _this.lang.add + ' ' + _this.lang.action; _this.categoriesList = data.categoriesList; _this.statusList = data.statusList; _this.actionPagesList = data.action_pagesList; _this.keywordsList = data.keywordsList; _this.loading = false; - setTimeout(function () { - $j("select").chosen({ width: "100%", disable_search_threshold: 10, search_contains: true }); - }, 0); }); } else { - _this.mode = 'update'; + _this.creationMode = false; _this.http.get(_this.coreUrl + 'rest/administration/actions/' + params['id']) .subscribe(function (data) { - _this.lang = data.lang; _this.action = data.action; - _this.lang.pageTitle = _this.lang.modify_action + ' : ' + _this.action.id; _this.categoriesList = data.categoriesList; _this.statusList = data.statusList; _this.actionPagesList = data.action_pagesList; _this.keywordsList = data.keywordsList; _this.loading = false; - setTimeout(function () { - $j("select").chosen({ width: "100%", disable_search_threshold: 10, search_contains: true }); - }, 0); }); } }); }; + ActionAdministrationComponent.prototype.clearSearch = function () { + this._search = ''; + }; ActionAdministrationComponent.prototype.onSubmit = function () { var _this = this; - //affect value of select - this.action.actionCategories = $j("#categorieslist").chosen().val(); - this.action.id_status = $j("#status").chosen().val(); - this.action.keyword = $j("#keyword").chosen().val(); - this.action.action_page = $j("#action_page").chosen().val(); - if (this.mode == 'create') { + if (this.creationMode) { this.http.post(this.coreUrl + 'rest/actions', this.action) .subscribe(function (data) { _this.router.navigate(['/administration/actions']); - successNotification(data.success); + _this.notify.success(_this.lang.actionAdded + ' « ' + _this.action.label_action + ' »'); }, function (err) { - errorNotification(JSON.parse(err._body).errors); + _this.notify.error(JSON.parse(err._body).errors); }); } - else if (this.mode == 'update') { + else { this.http.put(this.coreUrl + 'rest/actions/' + this.action.id, this.action) .subscribe(function (data) { _this.router.navigate(['/administration/actions']); - successNotification(data.success); + _this.notify.success(_this.lang.actionUpdated + ' « ' + _this.action.label_action + ' »'); }, function (err) { - errorNotification(JSON.parse(err._body).errors); + _this.notify.error(JSON.parse(err._body).errors); }); } }; - ActionAdministrationComponent.prototype.selectAll = function (event) { - var target = event.target.getAttribute("data-target"); - $j('#' + target + ' option').prop('selected', true); - $j('#' + target).trigger('chosen:updated'); - }; - ActionAdministrationComponent.prototype.unselectAll = function (event) { - var target = event.target.getAttribute("data-target"); - $j('#' + target + ' option').prop('selected', false); - $j('#' + target).trigger('chosen:updated'); - }; return ActionAdministrationComponent; }()); ActionAdministrationComponent = __decorate([ core_1.Component({ templateUrl: angularGlobals["action-administrationView"], - styleUrls: ['../../node_modules/bootstrap/dist/css/bootstrap.min.css', 'css/action-administration.component.css'] + styleUrls: ['css/action-administration.component.css'], + providers: [notification_service_1.NotificationService] }), - __metadata("design:paramtypes", [http_1.HttpClient, router_1.ActivatedRoute, router_1.Router]) + __metadata("design:paramtypes", [http_1.HttpClient, router_1.ActivatedRoute, router_1.Router, notification_service_1.NotificationService]) ], ActionAdministrationComponent); exports.ActionAdministrationComponent = ActionAdministrationComponent; diff --git a/apps/maarch_entreprise/js/angular/app/administration/action-administration.component.ts b/apps/maarch_entreprise/js/angular/app/administration/action-administration.component.ts index cdb8d853987cef9b8815d74f5e1f941924a70bfe..c257309cda734783d34c6f2911e275fee6654fd9 100755 --- a/apps/maarch_entreprise/js/angular/app/administration/action-administration.component.ts +++ b/apps/maarch_entreprise/js/angular/app/administration/action-administration.component.ts @@ -1,39 +1,44 @@ import { Component, OnInit } from '@angular/core'; import { HttpClient } from '@angular/common/http'; import { Router, ActivatedRoute } from '@angular/router'; +import { LANG } from '../translate.component'; +import { NotificationService } from '../notification.service'; declare function $j(selector: any) : any; -declare function successNotification(message: string) : void; -declare function errorNotification(message: string) : void; declare var angularGlobals : any; @Component({ templateUrl : angularGlobals["action-administrationView"], - styleUrls : ['../../node_modules/bootstrap/dist/css/bootstrap.min.css', 'css/action-administration.component.css'] + styleUrls : ['css/action-administration.component.css'], + providers : [NotificationService] }) export class ActionAdministrationComponent implements OnInit { - + lang : any = LANG; + _search : string = ''; coreUrl : string; - mode : string = null; + creationMode : boolean; action : any = {}; statusList : any[] = []; actionPagesList : any[] = []; - lang : any = {}; categoriesList : any[] = []; keywordsList : any[] = []; - resultInfo : string; loading : boolean = false; - constructor(public http: HttpClient, private route: ActivatedRoute, private router: Router){ + constructor(public http: HttpClient, private route: ActivatedRoute, private router: Router, private notify: NotificationService){ } updateBreadcrumb(applicationName: string) { - if ($j('#ariane')[0]) { - $j('#ariane')[0].innerHTML = "<a href='index.php?reinit=true'>" + applicationName + "</a> > <a onclick='location.hash = \"/administration\"' style='cursor: pointer'>Administration</a> > <a onclick='location.hash = \"/administration/actions\"' style='cursor: pointer'>Actions</a> > Modification"; + var breadCrumb = "<a href='index.php?reinit=true'>" + applicationName + "</a> > <a onclick='location.hash = \"/administration\"' style='cursor: pointer'>"+this.lang.administration+"</a> > <a onclick='location.hash = \"/administration/actions\"' style='cursor: pointer'>"+this.lang.actions+"</a> > "; + + if(this.creationMode == true){ + breadCrumb += this.lang.actionCreation; + } else { + breadCrumb += this.lang.actionModification; } + $j('#ariane')[0].innerHTML = breadCrumb; } prepareActions() { @@ -50,85 +55,59 @@ export class ActionAdministrationComponent implements OnInit { this.route.params.subscribe(params => { if(typeof params['id']== "undefined"){ - this.mode = 'create'; + this.creationMode = true; this.http.get(this.coreUrl + 'rest/initAction') .subscribe((data : any) => { this.action = data.action; - this.lang = data.lang; - this.lang.pageTitle = this.lang.add+' '+this.lang.action; this.categoriesList = data.categoriesList; this.statusList = data.statusList; this.actionPagesList = data.action_pagesList; this.keywordsList = data.keywordsList; this.loading = false; - setTimeout(() => { - $j("select").chosen({width:"100%",disable_search_threshold: 10, search_contains: true}); - }, 0); }); } else { - this.mode = 'update'; + this.creationMode = false; this.http.get(this.coreUrl + 'rest/administration/actions/' + params['id']) .subscribe((data : any) => { - this.lang= data.lang; this.action = data.action; - this.lang.pageTitle = this.lang.modify_action+' : '+this.action.id; this.categoriesList = data.categoriesList; this.statusList = data.statusList; this.actionPagesList = data.action_pagesList; this.keywordsList = data.keywordsList; this.loading = false; - setTimeout(() => { - $j("select").chosen({width:"100%",disable_search_threshold: 10, search_contains: true}); - }, 0); }); } }); } - onSubmit() { - //affect value of select - this.action.actionCategories = $j("#categorieslist").chosen().val(); - this.action.id_status = $j("#status").chosen().val(); - this.action.keyword = $j("#keyword").chosen().val(); - this.action.action_page = $j("#action_page").chosen().val(); + clearSearch(){ + this._search = ''; + } - if (this.mode == 'create') { + onSubmit() { + if (this.creationMode) { this.http.post(this.coreUrl + 'rest/actions', this.action) .subscribe((data : any) => { this.router.navigate(['/administration/actions']); - successNotification(data.success); + this.notify.success(this.lang.actionAdded+' « '+this.action.label_action+' »'); },(err) => { - errorNotification(JSON.parse(err._body).errors); + this.notify.error(JSON.parse(err._body).errors); }); - }else if (this.mode == 'update') { + }else{ this.http.put(this.coreUrl + 'rest/actions/' + this.action.id, this.action) .subscribe((data : any) => { this.router.navigate(['/administration/actions']); - successNotification(data.success); + this.notify.success(this.lang.actionUpdated+' « '+this.action.label_action+' »'); },(err) => { - errorNotification(JSON.parse(err._body).errors); + this.notify.error(JSON.parse(err._body).errors); }); } - - } - - selectAll(event:any){ - var target = event.target.getAttribute("data-target"); - $j('#' + target + ' option').prop('selected', true); - $j('#' + target).trigger('chosen:updated'); - - } - - unselectAll(event:any){ - var target = event.target.getAttribute("data-target"); - $j('#' + target + ' option').prop('selected', false); - $j('#' + target).trigger('chosen:updated'); } } \ No newline at end of file diff --git a/apps/maarch_entreprise/js/angular/app/administration/actions-administration.component.js b/apps/maarch_entreprise/js/angular/app/administration/actions-administration.component.js index ec65e4378b33ddddbdd560c40ebd1156341c5a90..3b5b6c263c916619dc3c5f25e98cd49c5b4eddd1 100755 --- a/apps/maarch_entreprise/js/angular/app/administration/actions-administration.component.js +++ b/apps/maarch_entreprise/js/angular/app/administration/actions-administration.component.js @@ -12,18 +12,21 @@ Object.defineProperty(exports, "__esModule", { value: true }); var core_1 = require("@angular/core"); var http_1 = require("@angular/common/http"); var translate_component_1 = require("../translate.component"); +var notification_service_1 = require("../notification.service"); var ActionsAdministrationComponent = (function () { - function ActionsAdministrationComponent(http) { + function ActionsAdministrationComponent(http, notify) { this.http = http; + this.notify = notify; this.lang = translate_component_1.LANG; + this.search = null; this.actions = []; this.titles = []; - this.resultInfo = ""; this.loading = false; + this.data = []; } ActionsAdministrationComponent.prototype.updateBreadcrumb = function (applicationName) { if ($j('#ariane')[0]) { - $j('#ariane')[0].innerHTML = "<a href='index.php?reinit=true'>" + applicationName + "</a> > <a onclick='location.hash = \"/administration\"' style='cursor: pointer'>Administration</a> > Actions"; + $j('#ariane')[0].innerHTML = "<a href='index.php?reinit=true'>" + applicationName + "</a> > <a onclick='location.hash = \"/administration\"' style='cursor: pointer'>" + this.lang.administration + "</a> > " + this.lang.actions; } }; ActionsAdministrationComponent.prototype.ngOnInit = function () { @@ -35,62 +38,26 @@ var ActionsAdministrationComponent = (function () { this.http.get(this.coreUrl + 'rest/administration/actions') .subscribe(function (data) { _this.actions = data['actions']; - _this.titles = data['titles']; + _this.data = _this.actions; + _this.loading = false; setTimeout(function () { - _this.table = $j('#actionsTable').DataTable({ - "dom": '<"datatablesLeft"l><"datatablesRight"f><"datatablesCenter"p>rt<"datatablesCenter"i><"clear">', - "lengthMenu": [10, 25, 50, 75, 100], - "oLanguage": { - "sLengthMenu": "<i class='fa fa-bars'></i> _MENU_", - "sZeroRecords": _this.lang.noResult, - "sInfo": "_START_ - _END_ / _TOTAL_ " + _this.lang.record, - "sSearch": "", - "oPaginate": { - "sFirst": "<<", - "sLast": ">>", - "sNext": _this.lang.next + " <i class='fa fa-caret-right'></i>", - "sPrevious": "<i class='fa fa-caret-left'></i> " + _this.lang.previous - }, - "sInfoEmpty": _this.lang.noRecord, - "sInfoFiltered": "(filtré de _MAX_ " + _this.lang.record + ")" - }, - "order": [[1, "asc"]], - "columnDefs": [ - { "orderable": false, "targets": 4 } - ], - "fnInitComplete": function () { - $j('#actionsTable').show(); - }, - stateSave: true - }); - $j('.dataTables_filter input').attr("placeholder", _this.lang.search); - $j('dataTables_filter input').addClass('form-control'); - $j(".datatablesLeft").css({ "float": "left" }); - $j(".datatablesCenter").css({ "text-align": "center" }); - $j(".datatablesRight").css({ "float": "right" }); + $j("[md2sortby='id']").click(); }, 0); - _this.loading = false; }, function (err) { console.log(err); location.href = "index.php"; }); }; - ActionsAdministrationComponent.prototype.deleteAction = function (id) { + ActionsAdministrationComponent.prototype.deleteAction = function (action) { var _this = this; - var r = confirm(this.lang.deleteMsg + ' ?'); + var r = confirm(this.lang.confirmAction + ' ' + this.lang.delete + ' « ' + action.label_action + ' »'); if (r) { - this.http.delete(this.coreUrl + 'rest/actions/' + id) + this.http.delete(this.coreUrl + 'rest/actions/' + action.id) .subscribe(function (data) { - var list = _this.actions; - for (var i = 0; i < list.length; i++) { - if (list[i].id == id) { - list.splice(i, 1); - } - } - _this.table.row($j("#" + id)).remove().draw(); - successNotification(data.success); + _this.data = data.action; + _this.notify.success(_this.lang.actionDeleted + ' « ' + action.label_action + ' »'); }, function (err) { - errorNotification(JSON.parse(err._body).errors); + _this.notify.error(JSON.parse(err._body).errors); }); } }; @@ -99,8 +66,9 @@ var ActionsAdministrationComponent = (function () { ActionsAdministrationComponent = __decorate([ core_1.Component({ templateUrl: angularGlobals["actions-administrationView"], - styleUrls: ['../../node_modules/bootstrap/dist/css/bootstrap.min.css'] + styleUrls: [], + providers: [notification_service_1.NotificationService] }), - __metadata("design:paramtypes", [http_1.HttpClient]) + __metadata("design:paramtypes", [http_1.HttpClient, notification_service_1.NotificationService]) ], ActionsAdministrationComponent); exports.ActionsAdministrationComponent = ActionsAdministrationComponent; diff --git a/apps/maarch_entreprise/js/angular/app/administration/actions-administration.component.ts b/apps/maarch_entreprise/js/angular/app/administration/actions-administration.component.ts index 81a6ca7c290221fc57e287c7654c84d8dd353c8d..9409c66a2cb3b58304f7c68479dfbc7e08ed0e10 100755 --- a/apps/maarch_entreprise/js/angular/app/administration/actions-administration.component.ts +++ b/apps/maarch_entreprise/js/angular/app/administration/actions-administration.component.ts @@ -1,36 +1,36 @@ import { Component, OnInit } from '@angular/core'; import { HttpClient } from '@angular/common/http'; import { LANG } from '../translate.component'; +import { NotificationService } from '../notification.service'; declare function $j(selector: any) : any; -declare function successNotification(message: string) : void; -declare function errorNotification(message: string) : void; declare var angularGlobals : any; @Component({ templateUrl : angularGlobals["actions-administrationView"], - styleUrls : ['../../node_modules/bootstrap/dist/css/bootstrap.min.css'] + styleUrls : [], + providers : [NotificationService] }) export class ActionsAdministrationComponent implements OnInit { coreUrl : string; lang : any = LANG; + search : string = null; actions : any[] = []; titles : any[] = []; - table : any; - resultInfo : string = ""; loading : boolean = false; + data : any = []; - constructor(public http: HttpClient) { + constructor(public http: HttpClient, private notify: NotificationService) { } updateBreadcrumb(applicationName: string) { if ($j('#ariane')[0]) { - $j('#ariane')[0].innerHTML = "<a href='index.php?reinit=true'>" + applicationName + "</a> > <a onclick='location.hash = \"/administration\"' style='cursor: pointer'>Administration</a> > Actions"; + $j('#ariane')[0].innerHTML = "<a href='index.php?reinit=true'>" + applicationName + "</a> > <a onclick='location.hash = \"/administration\"' style='cursor: pointer'>"+this.lang.administration+"</a> > "+this.lang.actions; } } @@ -45,65 +45,28 @@ export class ActionsAdministrationComponent implements OnInit { this.http.get(this.coreUrl + 'rest/administration/actions') .subscribe((data) => { this.actions = data['actions']; - this.titles = data['titles']; + this.data = this.actions; + this.loading = false; setTimeout(() => { - this.table = $j('#actionsTable').DataTable({ - "dom": '<"datatablesLeft"l><"datatablesRight"f><"datatablesCenter"p>rt<"datatablesCenter"i><"clear">', - "lengthMenu": [ 10, 25, 50, 75, 100 ], - "oLanguage": { - "sLengthMenu": "<i class='fa fa-bars'></i> _MENU_", - "sZeroRecords": this.lang.noResult, - "sInfo": "_START_ - _END_ / _TOTAL_ "+this.lang.record, - "sSearch": "", - "oPaginate": { - "sFirst": "<<", - "sLast": ">>", - "sNext": this.lang.next+" <i class='fa fa-caret-right'></i>", - "sPrevious": "<i class='fa fa-caret-left'></i> "+this.lang.previous - }, - "sInfoEmpty": this.lang.noRecord, - "sInfoFiltered": "(filtré de _MAX_ "+this.lang.record+")" - }, - "order": [[ 1, "asc" ]], - "columnDefs": [ - { "orderable": false, "targets": 4 } - ], - "fnInitComplete": function () { - $j('#actionsTable').show(); - }, - stateSave: true - }); - $j('.dataTables_filter input').attr("placeholder", this.lang.search); - $j('dataTables_filter input').addClass('form-control'); - $j(".datatablesLeft").css({"float":"left"}); - $j(".datatablesCenter").css({"text-align":"center"}); - $j(".datatablesRight").css({"float":"right"}); - + $j("[md2sortby='id']").click(); }, 0); - this.loading = false; }, (err) => { console.log(err); location.href = "index.php"; }); } - deleteAction(id: number) { - let r = confirm(this.lang.deleteMsg+' ?'); + deleteAction(action: any) { + let r = confirm(this.lang.confirmAction+' '+this.lang.delete+' « '+action.label_action+' »'); if (r) { - this.http.delete(this.coreUrl + 'rest/actions/' + id) + this.http.delete(this.coreUrl + 'rest/actions/' + action.id) .subscribe((data : any) => { - var list = this.actions; - for(var i = 0; i<list.length;i++){ - if(list[i].id==id){ - list.splice(i,1); - } - } - this.table.row($j("#"+id)).remove().draw(); - successNotification(data.success); + this.data = data.action; + this.notify.success(this.lang.actionDeleted+' « '+action.label_action+' »'); }, (err) => { - errorNotification(JSON.parse(err._body).errors); + this.notify.error(JSON.parse(err._body).errors); }); } } diff --git a/apps/maarch_entreprise/js/angular/app/administration/administration-routing.module.js b/apps/maarch_entreprise/js/angular/app/administration/administration-routing.module.js index 6db0c926959f9c969112aab280e8138112f5e4e2..d951ab9d25ae42800aec7c2466048a6b33369e5f 100755 --- a/apps/maarch_entreprise/js/angular/app/administration/administration-routing.module.js +++ b/apps/maarch_entreprise/js/angular/app/administration/administration-routing.module.js @@ -20,8 +20,8 @@ var parameters_administration_component_1 = require("./parameters-administration var priorities_administration_component_1 = require("./priorities-administration.component"); var priority_administration_component_1 = require("./priority-administration.component"); var reports_administration_component_1 = require("./reports-administration.component"); -var notifications_administration_component_1 = require("./notifications-administration.component"); -var notification_administration_component_1 = require("./notification-administration.component"); +var history_administration_component_1 = require("./history-administration.component"); +var historyBatch_administration_component_1 = require("./historyBatch-administration.component"); var AdministrationRoutingModule = (function () { function AdministrationRoutingModule() { } @@ -48,9 +48,8 @@ AdministrationRoutingModule = __decorate([ { path: 'administration/actions', component: actions_administration_component_1.ActionsAdministrationComponent }, { path: 'administration/actions/new', component: action_administration_component_1.ActionAdministrationComponent }, { path: 'administration/actions/:id', component: action_administration_component_1.ActionAdministrationComponent }, - { path: 'administration/notifications', component: notifications_administration_component_1.NotificationsAdministrationComponent }, - { path: 'administration/notifications/new', component: notification_administration_component_1.NotificationAdministrationComponent }, - { path: 'administration/notifications/:identifier', component: notification_administration_component_1.NotificationAdministrationComponent }, + { path: 'administration/history', component: history_administration_component_1.HistoryAdministrationComponent }, + { path: 'administration/historyBatch', component: historyBatch_administration_component_1.HistoryBatchAdministrationComponent }, ]), ], exports: [ diff --git a/apps/maarch_entreprise/js/angular/app/administration/administration-routing.module.ts b/apps/maarch_entreprise/js/angular/app/administration/administration-routing.module.ts index 429fbafa11a301bd83340d68dd089caaf04ae80d..6ce534e40cde0aaf0cf4ec804a20bc6c2c94fba1 100755 --- a/apps/maarch_entreprise/js/angular/app/administration/administration-routing.module.ts +++ b/apps/maarch_entreprise/js/angular/app/administration/administration-routing.module.ts @@ -13,8 +13,11 @@ import { ParametersAdministrationComponent } from './parameters-administratio import { PrioritiesAdministrationComponent } from './priorities-administration.component'; import { PriorityAdministrationComponent } from './priority-administration.component'; import { ReportsAdministrationComponent } from './reports-administration.component'; -import { NotificationsAdministrationComponent } from './notifications-administration.component'; -import { NotificationAdministrationComponent } from './notification-administration.component'; +import { NotificationsAdministrationComponent } from './notifications-administration.component'; +import { NotificationAdministrationComponent } from './notification-administration.component'; +import { HistoryAdministrationComponent } from './history-administration.component'; +import { HistoryBatchAdministrationComponent } from './historyBatch-administration.component'; + @NgModule({ imports: [ @@ -39,6 +42,8 @@ import { NotificationAdministrationComponent } from './notification-admini { path: 'administration/notifications', component: NotificationsAdministrationComponent }, { path: 'administration/notifications/new', component: NotificationAdministrationComponent }, { path: 'administration/notifications/:identifier', component: NotificationAdministrationComponent }, + { path: 'administration/history', component: HistoryAdministrationComponent }, + { path: 'administration/historyBatch', component: HistoryBatchAdministrationComponent }, ]), ], exports: [ diff --git a/apps/maarch_entreprise/js/angular/app/administration/administration.module.js b/apps/maarch_entreprise/js/angular/app/administration/administration.module.js index b87cc06c72bf37d96f376c65f8a8976647e05db5..725ffb3bcdc51de6e531926d60848a5e23e326bb 100755 --- a/apps/maarch_entreprise/js/angular/app/administration/administration.module.js +++ b/apps/maarch_entreprise/js/angular/app/administration/administration.module.js @@ -10,6 +10,7 @@ var core_1 = require("@angular/core"); var common_1 = require("@angular/common"); var forms_1 = require("@angular/forms"); var http_1 = require("@angular/common/http"); +var md2_1 = require("md2"); var app_material_module_1 = require("../app-material.module"); var administration_routing_module_1 = require("./administration-routing.module"); var administration_component_1 = require("./administration.component"); @@ -26,6 +27,8 @@ var parameter_administration_component_1 = require("./parameter-administration.c var priorities_administration_component_1 = require("./priorities-administration.component"); var priority_administration_component_1 = require("./priority-administration.component"); var reports_administration_component_1 = require("./reports-administration.component"); +var history_administration_component_1 = require("./history-administration.component"); +var historyBatch_administration_component_1 = require("./historyBatch-administration.component"); var AdministrationModule = (function () { function AdministrationModule() { } @@ -38,7 +41,8 @@ AdministrationModule = __decorate([ forms_1.FormsModule, http_1.HttpClientModule, app_material_module_1.AppMaterialModule, - administration_routing_module_1.AdministrationRoutingModule + administration_routing_module_1.AdministrationRoutingModule, + md2_1.Md2Module ], declarations: [ administration_component_1.AdministrationComponent, @@ -54,7 +58,10 @@ AdministrationModule = __decorate([ parameter_administration_component_1.ParameterAdministrationComponent, priorities_administration_component_1.PrioritiesAdministrationComponent, priority_administration_component_1.PriorityAdministrationComponent, - reports_administration_component_1.ReportsAdministrationComponent + reports_administration_component_1.ReportsAdministrationComponent, + history_administration_component_1.HistoryAdministrationComponent, + historyBatch_administration_component_1.HistoryBatchAdministrationComponent, + users_administration_component_1.DataTablePipe ] }) ], AdministrationModule); diff --git a/apps/maarch_entreprise/js/angular/app/administration/administration.module.ts b/apps/maarch_entreprise/js/angular/app/administration/administration.module.ts index 9351b3c2a95201206c44d41ae607029496cfd7c8..4299b86a1d491a8d538431d3914ffc779f1538f6 100755 --- a/apps/maarch_entreprise/js/angular/app/administration/administration.module.ts +++ b/apps/maarch_entreprise/js/angular/app/administration/administration.module.ts @@ -2,6 +2,7 @@ import { NgModule } from '@angular/core'; import { CommonModule } from '@angular/common'; import { FormsModule } from '@angular/forms'; import { HttpClientModule } from '@angular/common/http'; +import { Md2Module } from 'md2'; import { AppMaterialModule } from '../app-material.module'; import { AdministrationRoutingModule } from './administration-routing.module'; @@ -9,7 +10,7 @@ import { AdministrationRoutingModule } from './administration-routing.m import { AdministrationComponent } from './administration.component'; import { NotificationsAdministrationComponent } from './notifications-administration.component'; import { NotificationAdministrationComponent } from './notification-administration.component'; -import { UsersAdministrationComponent } from './users-administration.component'; +import { UsersAdministrationComponent, DataTablePipe } from './users-administration.component'; import { UserAdministrationComponent } from './user-administration.component'; import { StatusesAdministrationComponent } from './statuses-administration.component'; import { StatusAdministrationComponent } from './status-administration.component'; @@ -20,6 +21,9 @@ import { ParameterAdministrationComponent } from './parameter-administration import { PrioritiesAdministrationComponent } from './priorities-administration.component'; import { PriorityAdministrationComponent } from './priority-administration.component'; import { ReportsAdministrationComponent } from './reports-administration.component'; +import { HistoryAdministrationComponent } from './history-administration.component'; +import { HistoryBatchAdministrationComponent } from './historyBatch-administration.component'; + @NgModule({ imports: [ @@ -27,7 +31,8 @@ import { ReportsAdministrationComponent } from './reports-administration.c FormsModule, HttpClientModule, AppMaterialModule, - AdministrationRoutingModule + AdministrationRoutingModule, + Md2Module ], declarations: [ AdministrationComponent, @@ -43,7 +48,10 @@ import { ReportsAdministrationComponent } from './reports-administration.c ParameterAdministrationComponent, PrioritiesAdministrationComponent, PriorityAdministrationComponent, - ReportsAdministrationComponent + ReportsAdministrationComponent, + HistoryAdministrationComponent, + HistoryBatchAdministrationComponent, + DataTablePipe ] }) export class AdministrationModule { } \ No newline at end of file diff --git a/apps/maarch_entreprise/js/angular/app/administration/history-administration.component.js b/apps/maarch_entreprise/js/angular/app/administration/history-administration.component.js new file mode 100644 index 0000000000000000000000000000000000000000..fd6adb4d6eba071d027c59da41210b4b21c42d51 --- /dev/null +++ b/apps/maarch_entreprise/js/angular/app/administration/history-administration.component.js @@ -0,0 +1,83 @@ +"use strict"; +var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; +var __metadata = (this && this.__metadata) || function (k, v) { + if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); +}; +Object.defineProperty(exports, "__esModule", { value: true }); +var core_1 = require("@angular/core"); +var http_1 = require("@angular/common/http"); +var translate_component_1 = require("../translate.component"); +var notification_service_1 = require("../notification.service"); +var HistoryAdministrationComponent = (function () { + function HistoryAdministrationComponent(http, notify) { + this.http = http; + this.notify = notify; + this.lang = translate_component_1.LANG; + this.search = null; + this._search = ''; + this.filterEventTypes = []; + this.filterEventType = ''; + this.filterUsers = []; + this.filterUser = ''; + this.filterByDate = ''; + this.loading = false; + this.data = []; + this.CurrentYear = new Date().getFullYear(); + this.currentMonth = new Date().getMonth() + 1; + this.minDate = new Date(); + } + HistoryAdministrationComponent.prototype.updateBreadcrumb = function (applicationName) { + if ($j('#ariane')[0]) { + $j('#ariane')[0].innerHTML = "<a href='index.php?reinit=true'>" + applicationName + "</a> > <a onclick='location.hash = \"/administration\"' style='cursor: pointer'>" + this.lang.administration + "</a> > " + this.lang.history; + } + }; + HistoryAdministrationComponent.prototype.ngOnInit = function () { + var _this = this; + this.coreUrl = angularGlobals.coreUrl; + this.loading = true; + this.updateBreadcrumb(angularGlobals.applicationName); + $j('#inner_content').remove(); + this.minDate = new Date(this.CurrentYear + '-' + this.currentMonth + '-01'); + console.log(this.minDate.toJSON()); + this.http.get(this.coreUrl + 'rest/administration/history/eventDate/' + this.minDate.toJSON()) + .subscribe(function (data) { + _this.data = data.historyList; + _this.filterEventTypes = data.filters.eventType; + _this.filterUsers = data.filters.users; + _this.loading = false; + setTimeout(function () { + $j("[md2sortby='event_date']").click().click(); + }, 0); + }, function (err) { + console.log(err); + location.href = "index.php"; + }); + }; + HistoryAdministrationComponent.prototype.refreshHistory = function () { + var _this = this; + this.http.get(this.coreUrl + 'rest/administration/history/eventDate/' + this.minDate.toJSON()) + .subscribe(function (data) { + _this.data = data.historyList; + _this.filterEventTypes = data.filters.eventType; + _this.filterUsers = data.filters.users; + }, function (err) { + console.log(err); + location.href = "index.php"; + }); + }; + return HistoryAdministrationComponent; +}()); +HistoryAdministrationComponent = __decorate([ + core_1.Component({ + templateUrl: angularGlobals["history-administrationView"], + styleUrls: [], + providers: [notification_service_1.NotificationService] + }), + __metadata("design:paramtypes", [http_1.HttpClient, notification_service_1.NotificationService]) +], HistoryAdministrationComponent); +exports.HistoryAdministrationComponent = HistoryAdministrationComponent; diff --git a/apps/maarch_entreprise/js/angular/app/administration/history-administration.component.ts b/apps/maarch_entreprise/js/angular/app/administration/history-administration.component.ts new file mode 100644 index 0000000000000000000000000000000000000000..8e0a1489db80961958d69b53763f0abe4533458a --- /dev/null +++ b/apps/maarch_entreprise/js/angular/app/administration/history-administration.component.ts @@ -0,0 +1,85 @@ +import { Component, OnInit } from '@angular/core'; +import { HttpClient } from '@angular/common/http'; +import { LANG } from '../translate.component'; +import { NotificationService } from '../notification.service'; + +declare function $j(selector: any) : any; + +declare var angularGlobals : any; + + +@Component({ + templateUrl : angularGlobals["history-administrationView"], + styleUrls : [], + providers : [NotificationService] +}) + +export class HistoryAdministrationComponent implements OnInit { + coreUrl : string; + lang : any = LANG; + search : string = null; + _search : string = ''; + + filterEventTypes : any = []; + filterEventType : string = ''; + filterUsers : any = []; + filterUser : string = ''; + filterByDate : string = ''; + + loading : boolean = false; + data : any = []; + CurrentYear : number = new Date().getFullYear(); + currentMonth : number = new Date().getMonth()+1; + minDate : Date = new Date(); + + + constructor(public http: HttpClient, private notify: NotificationService) { + } + + updateBreadcrumb(applicationName: string) { + if ($j('#ariane')[0]) { + $j('#ariane')[0].innerHTML = "<a href='index.php?reinit=true'>" + applicationName + "</a> > <a onclick='location.hash = \"/administration\"' style='cursor: pointer'>"+this.lang.administration+"</a> > "+this.lang.history; + } + } + + ngOnInit(): void { + this.coreUrl = angularGlobals.coreUrl; + + this.loading = true; + + this.updateBreadcrumb(angularGlobals.applicationName); + $j('#inner_content').remove(); + + this.minDate = new Date(this.CurrentYear+'-'+this.currentMonth+'-01'); + console.log(this.minDate.toJSON()); + this.http.get(this.coreUrl + 'rest/administration/history/eventDate/'+this.minDate.toJSON()) + .subscribe((data:any) => { + this.data = data.historyList; + + this.filterEventTypes = data.filters.eventType; + this.filterUsers = data.filters.users; + this.loading = false; + setTimeout(() => { + + $j("[md2sortby='event_date']").click().click(); + }, 0); + }, (err) => { + console.log(err); + location.href = "index.php"; + }); + } + + refreshHistory() { + this.http.get(this.coreUrl + 'rest/administration/history/eventDate/'+this.minDate.toJSON()) + .subscribe((data:any) => { + this.data = data.historyList; + this.filterEventTypes = data.filters.eventType; + this.filterUsers = data.filters.users; + + }, (err) => { + console.log(err); + location.href = "index.php"; + }); + } + +} \ No newline at end of file diff --git a/apps/maarch_entreprise/js/angular/app/administration/historyBatch-administration.component.js b/apps/maarch_entreprise/js/angular/app/administration/historyBatch-administration.component.js new file mode 100644 index 0000000000000000000000000000000000000000..5c675399b0f18f6b9970c128ca76052fc5298d7f --- /dev/null +++ b/apps/maarch_entreprise/js/angular/app/administration/historyBatch-administration.component.js @@ -0,0 +1,78 @@ +"use strict"; +var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; +var __metadata = (this && this.__metadata) || function (k, v) { + if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); +}; +Object.defineProperty(exports, "__esModule", { value: true }); +var core_1 = require("@angular/core"); +var http_1 = require("@angular/common/http"); +var translate_component_1 = require("../translate.component"); +var notification_service_1 = require("../notification.service"); +var HistoryBatchAdministrationComponent = (function () { + function HistoryBatchAdministrationComponent(http, notify) { + this.http = http; + this.notify = notify; + this.lang = translate_component_1.LANG; + this.search = null; + this._search = ''; + this.filterModules = []; + this.filterModule = ''; + this.filterByDate = ''; + this.loading = false; + this.data = []; + this.CurrentYear = new Date().getFullYear(); + this.currentMonth = new Date().getMonth() + 1; + this.minDate = new Date(); + } + HistoryBatchAdministrationComponent.prototype.updateBreadcrumb = function (applicationName) { + if ($j('#ariane')[0]) { + $j('#ariane')[0].innerHTML = "<a href='index.php?reinit=true'>" + applicationName + "</a> > <a onclick='location.hash = \"/administration\"' style='cursor: pointer'>" + this.lang.administration + "</a> > " + this.lang.historyBatch; + } + }; + HistoryBatchAdministrationComponent.prototype.ngOnInit = function () { + var _this = this; + this.coreUrl = angularGlobals.coreUrl; + this.loading = true; + this.updateBreadcrumb(angularGlobals.applicationName); + $j('#inner_content').remove(); + this.minDate = new Date(this.CurrentYear + '-' + this.currentMonth + '-01'); + this.http.get(this.coreUrl + 'rest/administration/historyBatch/eventDate/' + this.minDate.toJSON()) + .subscribe(function (data) { + _this.data = data.historyList; + _this.filterModules = data.filters.modules; + _this.loading = false; + setTimeout(function () { + $j("[md2sortby='event_date']").click().click(); + }, 0); + }, function (err) { + console.log(err); + location.href = "index.php"; + }); + }; + HistoryBatchAdministrationComponent.prototype.refreshHistory = function () { + var _this = this; + this.http.get(this.coreUrl + 'rest/administration/historyBatch/eventDate/' + this.minDate.toJSON()) + .subscribe(function (data) { + _this.data = data.historyList; + _this.filterModules = data.filters.modules; + }, function (err) { + console.log(err); + location.href = "index.php"; + }); + }; + return HistoryBatchAdministrationComponent; +}()); +HistoryBatchAdministrationComponent = __decorate([ + core_1.Component({ + templateUrl: angularGlobals["historyBatch-administrationView"], + styleUrls: [], + providers: [notification_service_1.NotificationService] + }), + __metadata("design:paramtypes", [http_1.HttpClient, notification_service_1.NotificationService]) +], HistoryBatchAdministrationComponent); +exports.HistoryBatchAdministrationComponent = HistoryBatchAdministrationComponent; diff --git a/apps/maarch_entreprise/js/angular/app/administration/historyBatch-administration.component.ts b/apps/maarch_entreprise/js/angular/app/administration/historyBatch-administration.component.ts new file mode 100644 index 0000000000000000000000000000000000000000..5b518197c0b1a448afd01e8b952f9047dbea062d --- /dev/null +++ b/apps/maarch_entreprise/js/angular/app/administration/historyBatch-administration.component.ts @@ -0,0 +1,80 @@ +import { Component, OnInit } from '@angular/core'; +import { HttpClient } from '@angular/common/http'; +import { LANG } from '../translate.component'; +import { NotificationService } from '../notification.service'; + +declare function $j(selector: any) : any; + +declare var angularGlobals : any; + + +@Component({ + templateUrl : angularGlobals["historyBatch-administrationView"], + styleUrls : [], + providers : [NotificationService] +}) + +export class HistoryBatchAdministrationComponent implements OnInit { + coreUrl : string; + lang : any = LANG; + search : string = null; + _search : string = ''; + + filterModules : any = []; + filterModule : string = ''; + filterByDate : string = ''; + + loading : boolean = false; + data : any = []; + CurrentYear : number = new Date().getFullYear(); + currentMonth : number = new Date().getMonth()+1; + minDate : Date = new Date(); + + + constructor(public http: HttpClient, private notify: NotificationService) { + } + + updateBreadcrumb(applicationName: string) { + if ($j('#ariane')[0]) { + $j('#ariane')[0].innerHTML = "<a href='index.php?reinit=true'>" + applicationName + "</a> > <a onclick='location.hash = \"/administration\"' style='cursor: pointer'>"+this.lang.administration+"</a> > "+this.lang.historyBatch; + } + } + + ngOnInit(): void { + this.coreUrl = angularGlobals.coreUrl; + + this.loading = true; + + this.updateBreadcrumb(angularGlobals.applicationName); + $j('#inner_content').remove(); + + this.minDate = new Date(this.CurrentYear+'-'+this.currentMonth+'-01'); + + this.http.get(this.coreUrl + 'rest/administration/historyBatch/eventDate/'+this.minDate.toJSON()) + .subscribe((data:any) => { + this.data = data.historyList; + + this.filterModules = data.filters.modules; + this.loading = false; + setTimeout(() => { + $j("[md2sortby='event_date']").click().click(); + }, 0); + }, (err) => { + console.log(err); + location.href = "index.php"; + }); + } + + refreshHistory() { + this.http.get(this.coreUrl + 'rest/administration/historyBatch/eventDate/'+this.minDate.toJSON()) + .subscribe((data:any) => { + this.data = data.historyList; + this.filterModules = data.filters.modules; + + }, (err) => { + console.log(err); + location.href = "index.php"; + }); + } + +} \ No newline at end of file diff --git a/apps/maarch_entreprise/js/angular/app/administration/parameter-administration.component.js b/apps/maarch_entreprise/js/angular/app/administration/parameter-administration.component.js index 822d5fa1b43d4f0abf90e0d45955cbcd7a959993..8e2f907c4ee81778aeeaf094f337520498b9b983 100755 --- a/apps/maarch_entreprise/js/angular/app/administration/parameter-administration.component.js +++ b/apps/maarch_entreprise/js/angular/app/administration/parameter-administration.component.js @@ -12,31 +12,43 @@ Object.defineProperty(exports, "__esModule", { value: true }); var core_1 = require("@angular/core"); var http_1 = require("@angular/common/http"); var router_1 = require("@angular/router"); +var translate_component_1 = require("../translate.component"); +var notification_service_1 = require("../notification.service"); var ParameterAdministrationComponent = (function () { - function ParameterAdministrationComponent(http, route, router) { + function ParameterAdministrationComponent(http, route, router, notify) { this.http = http; this.route = route; this.router = router; - this.creationMode = true; + this.notify = notify; + this.lang = translate_component_1.LANG; + this._search = ''; this.parameter = {}; - this.lang = ""; - this.resultInfo = ""; this.loading = false; } + ParameterAdministrationComponent.prototype.prepareParameter = function () { + $j('#inner_content').remove(); + }; + ParameterAdministrationComponent.prototype.updateBreadcrumb = function (applicationName) { + var breadCrumb = "<a href='index.php?reinit=true'>" + applicationName + "</a> > <a onclick='location.hash = \"/administration\"' style='cursor: pointer'>" + this.lang.administration + "</a> > <a onclick='location.hash = \"/administration/parameters\"' style='cursor: pointer'>" + this.lang.parameters + "</a> > "; + if (this.creationMode == true) { + breadCrumb += this.lang.parameterCreation; + } + else { + breadCrumb += this.lang.parameterModification; + } + $j('#ariane')[0].innerHTML = breadCrumb; + }; ParameterAdministrationComponent.prototype.ngOnInit = function () { var _this = this; this.loading = true; this.coreUrl = angularGlobals.coreUrl; - this.prepareParameter(); - this.updateBreadcrumb(angularGlobals.applicationName); this.route.params.subscribe(function (params) { if (typeof params['id'] == "undefined") { _this.creationMode = true; _this.http.get(_this.coreUrl + 'rest/administration/parameters/new') .subscribe(function (data) { - _this.lang = data.lang; _this.type = 'string'; - _this.pageTitle = _this.lang.newParameter; + _this.updateBreadcrumb(angularGlobals.applicationName); _this.loading = false; }, function () { location.href = "index.php"; @@ -47,8 +59,8 @@ var ParameterAdministrationComponent = (function () { _this.http.get(_this.coreUrl + 'rest/administration/parameters/' + params['id']) .subscribe(function (data) { _this.parameter = data.parameter; - _this.lang = data.lang; _this.type = data.type; + _this.updateBreadcrumb(angularGlobals.applicationName); _this.loading = false; }, function () { location.href = "index.php"; @@ -56,18 +68,9 @@ var ParameterAdministrationComponent = (function () { } }); }; - ParameterAdministrationComponent.prototype.prepareParameter = function () { - $j('#inner_content').remove(); - }; - ParameterAdministrationComponent.prototype.updateBreadcrumb = function (applicationName) { - if ($j('#ariane')[0]) { - $j('#ariane')[0].innerHTML = "<a href='index.php?reinit=true'>" + applicationName + "</a> > <a onclick='location.hash = \"/administration\"' style='cursor: pointer'>Administration</a> > <a onclick='location.hash = \"/administration/parameters\"' style='cursor: pointer'>Paramètres</a> > Modification"; - } - }; ParameterAdministrationComponent.prototype.onSubmit = function () { var _this = this; if (this.type == 'date') { - this.parameter.param_value_date = $j("#paramValue").val(); this.parameter.param_value_int = null; this.parameter.param_value_string = null; } @@ -83,18 +86,18 @@ var ParameterAdministrationComponent = (function () { this.http.post(this.coreUrl + 'rest/parameters', this.parameter) .subscribe(function (data) { _this.router.navigate(['administration/parameters']); - successNotification(data.success); + _this.notify.success(_this.lang.parameterAdded + ' « ' + _this.parameter.id + ' »'); }, function (err) { - errorNotification(JSON.parse(err._body).errors); + _this.notify.error(err.error.errors); }); } else if (this.creationMode == false) { this.http.put(this.coreUrl + 'rest/parameters/' + this.parameter.id, this.parameter) .subscribe(function (data) { _this.router.navigate(['administration/parameters']); - successNotification(data.success); + _this.notify.success(_this.lang.parameterUpdated + ' « ' + _this.parameter.id + ' »'); }, function (err) { - errorNotification(JSON.parse(err._body).errors); + _this.notify.error(err.error.errors); }); } }; @@ -103,8 +106,9 @@ var ParameterAdministrationComponent = (function () { ParameterAdministrationComponent = __decorate([ core_1.Component({ templateUrl: angularGlobals['parameter-administrationView'], - styleUrls: ['../../node_modules/bootstrap/dist/css/bootstrap.min.css'] + styleUrls: [], + providers: [notification_service_1.NotificationService] }), - __metadata("design:paramtypes", [http_1.HttpClient, router_1.ActivatedRoute, router_1.Router]) + __metadata("design:paramtypes", [http_1.HttpClient, router_1.ActivatedRoute, router_1.Router, notification_service_1.NotificationService]) ], ParameterAdministrationComponent); exports.ParameterAdministrationComponent = ParameterAdministrationComponent; diff --git a/apps/maarch_entreprise/js/angular/app/administration/parameter-administration.component.ts b/apps/maarch_entreprise/js/angular/app/administration/parameter-administration.component.ts index e71eb48a6f61517405cd9aeb261d74847d0cb67a..43c763d1eb7946805094ece8460693cb1e8177be 100755 --- a/apps/maarch_entreprise/js/angular/app/administration/parameter-administration.component.ts +++ b/apps/maarch_entreprise/js/angular/app/administration/parameter-administration.component.ts @@ -1,37 +1,51 @@ import { Component, OnInit} from '@angular/core'; import { HttpClient } from '@angular/common/http'; import { Router, ActivatedRoute } from '@angular/router'; +import { LANG } from '../translate.component'; +import { NotificationService } from '../notification.service'; declare function $j(selector: any) : any; -declare function successNotification(message: string) : void; -declare function errorNotification(message: string) : void; declare var angularGlobals : any; @Component({ templateUrl : angularGlobals['parameter-administrationView'], - styleUrls : ['../../node_modules/bootstrap/dist/css/bootstrap.min.css'] + styleUrls : [], + providers : [NotificationService] }) export class ParameterAdministrationComponent implements OnInit { coreUrl : string; - pageTitle : string; - creationMode : boolean = true; + + lang : any = LANG; + _search : string = ''; + creationMode : boolean; + type : string; parameter : any = {}; paramDateTemp : string; - lang : any = ""; - resultInfo : string = ""; loading : boolean = false; - constructor(public http: HttpClient, private route: ActivatedRoute, private router: Router) { + constructor(public http: HttpClient, private route: ActivatedRoute, private router: Router, private notify: NotificationService) { + } + + prepareParameter() { + $j('#inner_content').remove(); } + updateBreadcrumb(applicationName: string) { + var breadCrumb = "<a href='index.php?reinit=true'>" + applicationName + "</a> > <a onclick='location.hash = \"/administration\"' style='cursor: pointer'>"+this.lang.administration+"</a> > <a onclick='location.hash = \"/administration/parameters\"' style='cursor: pointer'>"+this.lang.parameters+"</a> > "; + + if(this.creationMode == true){ + breadCrumb += this.lang.parameterCreation; + } else { + breadCrumb += this.lang.parameterModification; + } + $j('#ariane')[0].innerHTML = breadCrumb; + } ngOnInit(): void { this.loading = true; this.coreUrl = angularGlobals.coreUrl; - this.prepareParameter(); - this.updateBreadcrumb(angularGlobals.applicationName); this.route.params.subscribe((params) => { if (typeof params['id'] == "undefined"){ @@ -39,10 +53,8 @@ export class ParameterAdministrationComponent implements OnInit { this.http.get(this.coreUrl + 'rest/administration/parameters/new') .subscribe((data : any) => { - this.lang = data.lang; this.type = 'string'; - this.pageTitle = this.lang.newParameter; - + this.updateBreadcrumb(angularGlobals.applicationName); this.loading = false; }, () => { @@ -53,9 +65,8 @@ export class ParameterAdministrationComponent implements OnInit { this.http.get(this.coreUrl + 'rest/administration/parameters/'+params['id']) .subscribe((data : any) => { this.parameter = data.parameter; - this.lang = data.lang; this.type = data.type; - + this.updateBreadcrumb(angularGlobals.applicationName); this.loading = false; }, () => { @@ -66,19 +77,8 @@ export class ParameterAdministrationComponent implements OnInit { } - prepareParameter() { - $j('#inner_content').remove(); - } - - updateBreadcrumb(applicationName: string){ - if ($j('#ariane')[0]) { - $j('#ariane')[0].innerHTML = "<a href='index.php?reinit=true'>" + applicationName + "</a> > <a onclick='location.hash = \"/administration\"' style='cursor: pointer'>Administration</a> > <a onclick='location.hash = \"/administration/parameters\"' style='cursor: pointer'>Paramètres</a> > Modification"; - } - } - onSubmit() { if(this.type=='date'){ - this.parameter.param_value_date = $j("#paramValue").val(); this.parameter.param_value_int=null; this.parameter.param_value_string=null; } @@ -95,19 +95,18 @@ export class ParameterAdministrationComponent implements OnInit { this.http.post(this.coreUrl + 'rest/parameters', this.parameter) .subscribe((data : any) => { this.router.navigate(['administration/parameters']); - successNotification(data.success); + this.notify.success(this.lang.parameterAdded+' « '+this.parameter.id+' »'); },(err) => { - errorNotification(JSON.parse(err._body).errors); + this.notify.error(err.error.errors); }); } else if(this.creationMode == false){ - this.http.put(this.coreUrl+'rest/parameters/'+this.parameter.id,this.parameter) .subscribe((data : any) => { this.router.navigate(['administration/parameters']); - successNotification(data.success); + this.notify.success(this.lang.parameterUpdated+' « '+this.parameter.id+' »'); },(err) => { - errorNotification(JSON.parse(err._body).errors); + this.notify.error(err.error.errors); }); } } diff --git a/apps/maarch_entreprise/js/angular/app/administration/parameters-administration.component.js b/apps/maarch_entreprise/js/angular/app/administration/parameters-administration.component.js index 995e9819bf9f4ac41f4763d383c9a8fb31955446..ea0b3ee45759ba1306a32fedbafcb5046cb41e89 100755 --- a/apps/maarch_entreprise/js/angular/app/administration/parameters-administration.component.js +++ b/apps/maarch_entreprise/js/angular/app/administration/parameters-administration.component.js @@ -11,70 +11,35 @@ var __metadata = (this && this.__metadata) || function (k, v) { Object.defineProperty(exports, "__esModule", { value: true }); var core_1 = require("@angular/core"); var http_1 = require("@angular/common/http"); +var translate_component_1 = require("../translate.component"); +var notification_service_1 = require("../notification.service"); var ParametersAdministrationComponent = (function () { - function ParametersAdministrationComponent(http) { + function ParametersAdministrationComponent(http, notify) { this.http = http; - this.lang = ""; + this.notify = notify; + this.lang = translate_component_1.LANG; + this.search = null; this.resultInfo = ""; this.loading = false; + this.data = []; } - ParametersAdministrationComponent.prototype.prepareParameter = function () { - $j('#inner_content').remove(); - }; ParametersAdministrationComponent.prototype.updateBreadcrumb = function (applicationName) { - $j('#ariane')[0].innerHTML = "<a href='index.php?reinit=true'>" + applicationName + "</a> > <a onclick='location.hash = \"/administration\"' style='cursor: pointer'>Administration</a> > Paramètres"; + if ($j('#ariane')[0]) { + $j('#ariane')[0].innerHTML = "<a href='index.php?reinit=true'>" + applicationName + "</a> > <a onclick='location.hash = \"/administration\"' style='cursor: pointer'>" + this.lang.administration + "</a> > " + this.lang.parameters; + } }; ParametersAdministrationComponent.prototype.ngOnInit = function () { var _this = this; - this.coreUrl = angularGlobals.coreUrl; - this.prepareParameter(); this.updateBreadcrumb(angularGlobals.applicationName); + this.coreUrl = angularGlobals.coreUrl; this.http.get(this.coreUrl + 'rest/administration/parameters') .subscribe(function (data) { - if (data.errors) { - $j('#resultInfo').removeClass().addClass('alert alert-danger alert-dismissible'); - $j("#resultInfo").fadeTo(3000, 500).slideUp(500, function () { - $j("#resultInfo").slideUp(500); - }); - } - else { - _this.parametersList = data.parametersList; - _this.lang = data.lang; - setTimeout(function () { - _this.table = $j('#paramsTable').DataTable({ - "dom": '<"datatablesLeft"l><"datatablesRight"f><"datatablesCenter"p>rt<"datatablesCenter"i><"clear">', - "lengthMenu": [10, 25, 50, 75, 100], - "oLanguage": { - "sLengthMenu": "<i class='fa fa-bars'></i> _MENU_", - "sZeroRecords": _this.lang.noResult, - "sInfo": "_START_ - _END_ / _TOTAL_ " + _this.lang.record, - "sSearch": "", - "oPaginate": { - "sFirst": "<<", - "sLast": ">>", - "sNext": _this.lang.next + " <i class='fa fa-caret-right'></i>", - "sPrevious": "<i class='fa fa-caret-left'></i> " + _this.lang.previous - }, - "sInfoEmpty": _this.lang.noRecord, - "sInfoFiltered": "(filtré de _MAX_ " + _this.lang.record + ")" - }, - "order": [[0, "asc"]], - "columnDefs": [ - { "orderable": false, "targets": 3 } - ], - "fnInitComplete": function () { - $j('#paramsTable').show(); - }, - stateSave: true - }); - $j('.dataTables_filter input').attr("placeholder", _this.lang.search); - $j('dataTables_filter input').addClass('form-control'); - $j(".datatablesLeft").css({ "float": "left" }); - $j(".datatablesCenter").css({ "text-align": "center" }); - $j(".datatablesRight").css({ "float": "right" }); - }, 0); - _this.loading = false; - } + _this.parametersList = data.parametersList; + _this.data = _this.parametersList; + setTimeout(function () { + $j("[md2sortby='id']").click(); + }, 0); + _this.loading = false; }); }; ParametersAdministrationComponent.prototype.goUrl = function () { @@ -82,19 +47,14 @@ var ParametersAdministrationComponent = (function () { }; ParametersAdministrationComponent.prototype.deleteParameter = function (paramId) { var _this = this; - var resp = confirm(this.lang.deleteConfirm + ' ' + paramId + '?'); + var resp = confirm(this.lang.confirmAction + ' ' + this.lang.delete + ' « ' + paramId + ' »'); if (resp) { this.http.delete(this.coreUrl + 'rest/parameters/' + paramId) .subscribe(function (data) { - for (var i = 0; i < _this.parametersList.length; i++) { - if (_this.parametersList[i].id == paramId) { - _this.parametersList.splice(i, 1); - } - } - _this.table.row($j("#" + paramId)).remove().draw(); - successNotification(data.success); + _this.data = data.parameters; + _this.notify.success(_this.lang.parameterDeleted + ' « ' + paramId + ' »'); }, function (err) { - errorNotification(JSON.parse(err._body).errors); + _this.notify.error(JSON.parse(err._body).errors); }); } }; @@ -103,8 +63,9 @@ var ParametersAdministrationComponent = (function () { ParametersAdministrationComponent = __decorate([ core_1.Component({ templateUrl: angularGlobals["parameters-administrationView"], - styleUrls: ['../../node_modules/bootstrap/dist/css/bootstrap.min.css', 'css/parameters-administration.component.css'] + styleUrls: ['css/parameters-administration.component.css'], + providers: [notification_service_1.NotificationService] }), - __metadata("design:paramtypes", [http_1.HttpClient]) + __metadata("design:paramtypes", [http_1.HttpClient, notification_service_1.NotificationService]) ], ParametersAdministrationComponent); exports.ParametersAdministrationComponent = ParametersAdministrationComponent; diff --git a/apps/maarch_entreprise/js/angular/app/administration/parameters-administration.component.ts b/apps/maarch_entreprise/js/angular/app/administration/parameters-administration.component.ts index 240d8201dc0ba05391ea8d29a2e54537bf668339..2cd18ed0456c77bfaed83964de707e4884336ce6 100755 --- a/apps/maarch_entreprise/js/angular/app/administration/parameters-administration.component.ts +++ b/apps/maarch_entreprise/js/angular/app/administration/parameters-administration.component.ts @@ -1,93 +1,53 @@ import { Component, OnInit } from '@angular/core'; import { HttpClient } from '@angular/common/http'; +import { LANG } from '../translate.component'; +import { NotificationService } from '../notification.service'; declare function $j(selector: any) : any; -declare function successNotification(message: string) : void; -declare function errorNotification(message: string) : void; declare var angularGlobals : any; @Component({ templateUrl : angularGlobals["parameters-administrationView"], - styleUrls : ['../../node_modules/bootstrap/dist/css/bootstrap.min.css','css/parameters-administration.component.css'] + styleUrls : ['css/parameters-administration.component.css'], + providers : [NotificationService] }) export class ParametersAdministrationComponent implements OnInit { coreUrl : string; - parametersList : any; - pageTitle : string; - lang : any = ""; - table : any; - + lang : any = LANG; + search : string = null; + + parametersList : any; resultInfo : string = ""; loading : boolean = false; + data : any = []; - constructor(public http: HttpClient) { - } - - prepareParameter() { - $j('#inner_content').remove(); + constructor(public http: HttpClient, private notify: NotificationService) { } - updateBreadcrumb(applicationName: string){ - $j('#ariane')[0].innerHTML = "<a href='index.php?reinit=true'>" + applicationName + "</a> > <a onclick='location.hash = \"/administration\"' style='cursor: pointer'>Administration</a> > Paramètres"; + updateBreadcrumb(applicationName: string) { + if ($j('#ariane')[0]) { + $j('#ariane')[0].innerHTML = "<a href='index.php?reinit=true'>" + applicationName + "</a> > <a onclick='location.hash = \"/administration\"' style='cursor: pointer'>"+this.lang.administration+"</a> > "+this.lang.parameters; + } } ngOnInit(): void { + this.updateBreadcrumb(angularGlobals.applicationName); this.coreUrl = angularGlobals.coreUrl; - this.prepareParameter(); - this.updateBreadcrumb(angularGlobals.applicationName); - this.http.get(this.coreUrl + 'rest/administration/parameters') .subscribe((data : any) => { - if(data.errors){ - $j('#resultInfo').removeClass().addClass('alert alert-danger alert-dismissible'); - $j("#resultInfo").fadeTo(3000, 500).slideUp(500, function(){ - $j("#resultInfo").slideUp(500); - }); - } else { - this.parametersList = data.parametersList; - this.lang = data.lang; - setTimeout(() => { - this.table = $j('#paramsTable').DataTable({ - "dom": '<"datatablesLeft"l><"datatablesRight"f><"datatablesCenter"p>rt<"datatablesCenter"i><"clear">', - "lengthMenu": [ 10, 25, 50, 75, 100 ], - "oLanguage": { - "sLengthMenu": "<i class='fa fa-bars'></i> _MENU_", - "sZeroRecords": this.lang.noResult, - "sInfo": "_START_ - _END_ / _TOTAL_ "+this.lang.record, - "sSearch": "", - "oPaginate": { - "sFirst": "<<", - "sLast": ">>", - "sNext": this.lang.next+" <i class='fa fa-caret-right'></i>", - "sPrevious": "<i class='fa fa-caret-left'></i> "+this.lang.previous - }, - "sInfoEmpty": this.lang.noRecord, - "sInfoFiltered": "(filtré de _MAX_ "+this.lang.record+")" - }, - "order": [[ 0, "asc" ]], - "columnDefs": [ - { "orderable": false, "targets": 3 } - ], - "fnInitComplete": function () { - $j('#paramsTable').show(); - }, - stateSave: true - }); - $j('.dataTables_filter input').attr("placeholder", this.lang.search); - $j('dataTables_filter input').addClass('form-control'); - $j(".datatablesLeft").css({"float":"left"}); - $j(".datatablesCenter").css({"text-align":"center"}); - $j(".datatablesRight").css({"float":"right"}); - + this.parametersList = data.parametersList; + this.data = this.parametersList; + setTimeout(() => { + $j("[md2sortby='id']").click(); }, 0); this.loading = false; - } + }); } @@ -96,19 +56,14 @@ export class ParametersAdministrationComponent implements OnInit { } deleteParameter(paramId : string){ - var resp =confirm(this.lang.deleteConfirm+' '+paramId+'?'); + let resp = confirm(this.lang.confirmAction+' '+this.lang.delete+' « '+paramId+' »'); if (resp) { this.http.delete(this.coreUrl + 'rest/parameters/'+paramId) .subscribe((data : any) => { - for(var i = 0; i<this.parametersList.length;i++){ - if(this.parametersList[i].id==paramId){ - this.parametersList.splice(i,1); - } - } - this.table.row($j("#"+paramId)).remove().draw(); - successNotification(data.success); + this.data = data.parameters; + this.notify.success(this.lang.parameterDeleted+' « '+paramId+' »'); },(err) => { - errorNotification(JSON.parse(err._body).errors); + this.notify.error(JSON.parse(err._body).errors); }); } } diff --git a/apps/maarch_entreprise/js/angular/app/administration/status-administration.component.js b/apps/maarch_entreprise/js/angular/app/administration/status-administration.component.js index e54c896e846af75920f51031ec411e4f8df528e7..79a3e6830d9bbc1c74e02a747795945d47f92b13 100755 --- a/apps/maarch_entreprise/js/angular/app/administration/status-administration.component.js +++ b/apps/maarch_entreprise/js/angular/app/administration/status-administration.component.js @@ -12,13 +12,15 @@ Object.defineProperty(exports, "__esModule", { value: true }); var core_1 = require("@angular/core"); var http_1 = require("@angular/common/http"); var router_1 = require("@angular/router"); +var translate_component_1 = require("../translate.component"); +var notification_service_1 = require("../notification.service"); var StatusAdministrationComponent = (function () { - function StatusAdministrationComponent(http, route, router) { + function StatusAdministrationComponent(http, route, router, notify) { this.http = http; this.route = route; this.router = router; - this.pageTitle = ""; - this.mode = null; + this.notify = notify; + this.lang = translate_component_1.LANG; this.status = { id: null, label_status: null, @@ -27,7 +29,6 @@ var StatusAdministrationComponent = (function () { is_folder_status: null, img_filename: null }; - this.lang = ""; this.statusImages = ""; this.loading = false; } @@ -40,39 +41,35 @@ var StatusAdministrationComponent = (function () { if (typeof params['identifier'] == "undefined") { _this.http.get(_this.coreUrl + 'rest/administration/status/new') .subscribe(function (data) { - _this.lang = data['lang']; + _this.status.img_filename = "fm-letter"; + _this.status.can_be_searched = true; + _this.status.can_be_modified = true; _this.statusImages = data['statusImages']; - _this.mode = 'create'; - _this.pageTitle = _this.lang.newStatus; + _this.creationMode = true; _this.updateBreadcrumb(angularGlobals.applicationName); + _this.loading = false; }); } else { - _this.mode = 'update'; + _this.creationMode = false; _this.statusIdentifier = params['identifier']; _this.getStatusInfos(_this.statusIdentifier); + _this.loading = false; } - setTimeout(function () { - $j(".help").tooltipster({ - theme: 'tooltipster-maarch', - interactive: true - }); - }, 0); }); - this.loading = false; }; StatusAdministrationComponent.prototype.prepareStatus = function () { $j('#inner_content').remove(); }; StatusAdministrationComponent.prototype.updateBreadcrumb = function (applicationName) { var breadCrumb = "<a href='index.php?reinit=true'>" + applicationName + "</a> > " + - "<a onclick='location.hash = \"/administration\"' style='cursor: pointer'>" + this.lang.admin + "</a> > " + - "<a onclick='location.hash = \"/administration/status\"' style='cursor: pointer'>" + this.lang.admin_status + "</a> > "; - if (this.mode == 'create') { - breadCrumb += this.lang.newItem; + "<a onclick='location.hash = \"/administration\"' style='cursor: pointer'>" + this.lang.administration + "</a> > " + + "<a onclick='location.hash = \"/administration/status\"' style='cursor: pointer'>" + this.lang.statuses + "</a> > "; + if (this.creationMode == true) { + breadCrumb += this.lang.statusCreation; } else { - breadCrumb += this.lang.modification; + breadCrumb += this.lang.statusModification; } $j('#ariane')[0].innerHTML = breadCrumb; }; @@ -99,35 +96,30 @@ var StatusAdministrationComponent = (function () { else { _this.status.is_folder_status = false; } - _this.lang = data['lang']; _this.statusImages = data['statusImages']; - _this.pageTitle = _this.lang.modify_status + ' : ' + _this.status.id; _this.updateBreadcrumb(angularGlobals.applicationName); }, function (err) { - errorNotification(JSON.parse(err._body).errors); + _this.notify.error(JSON.parse(err._body).errors); }); }; - StatusAdministrationComponent.prototype.selectImage = function (image_name) { - this.status.img_filename = image_name; - }; StatusAdministrationComponent.prototype.submitStatus = function () { var _this = this; - if (this.mode == 'create') { + if (this.creationMode == true) { this.http.post(this.coreUrl + 'rest/status', this.status) - .subscribe(function () { - successNotification(_this.lang.newStatusAdded + ' : ' + _this.status.id); + .subscribe(function (data) { + _this.notify.success(_this.lang.statusAdded + ' « ' + data.status.id + ' »'); _this.router.navigate(['administration/status']); }, function (err) { - errorNotification((JSON.parse(err._body).errors).join("<br>")); + _this.notify.error(JSON.parse(err._body).errors); }); } - else if (this.mode == "update") { + else if (this.creationMode == false) { this.http.put(this.coreUrl + 'rest/status/' + this.statusIdentifier, this.status) - .subscribe(function () { - successNotification(_this.lang.statusUpdated + ' : ' + _this.status.id); + .subscribe(function (data) { + _this.notify.success(_this.lang.statusUpdated + ' « ' + data.status.id + ' »'); _this.router.navigate(['administration/status']); }, function (err) { - errorNotification((JSON.parse(err._body).errors).join("<br>")); + _this.notify.error(JSON.parse(err._body).errors); }); } }; @@ -136,8 +128,9 @@ var StatusAdministrationComponent = (function () { StatusAdministrationComponent = __decorate([ core_1.Component({ templateUrl: angularGlobals['status-administrationView'], - styleUrls: ['../../node_modules/bootstrap/dist/css/bootstrap.min.css', 'css/status-administration.component.css'] + styleUrls: ['css/status-administration.component.css'], + providers: [notification_service_1.NotificationService] }), - __metadata("design:paramtypes", [http_1.HttpClient, router_1.ActivatedRoute, router_1.Router]) + __metadata("design:paramtypes", [http_1.HttpClient, router_1.ActivatedRoute, router_1.Router, notification_service_1.NotificationService]) ], StatusAdministrationComponent); exports.StatusAdministrationComponent = StatusAdministrationComponent; diff --git a/apps/maarch_entreprise/js/angular/app/administration/status-administration.component.ts b/apps/maarch_entreprise/js/angular/app/administration/status-administration.component.ts index 5cd7b9549ce764565d8facff6cc393395ceac5f6..caad7f78d19f0e551c27d82e4986eb2a7e105458 100755 --- a/apps/maarch_entreprise/js/angular/app/administration/status-administration.component.ts +++ b/apps/maarch_entreprise/js/angular/app/administration/status-administration.component.ts @@ -1,66 +1,66 @@ import { Component, OnInit} from '@angular/core'; import { HttpClient } from '@angular/common/http'; import { Router, ActivatedRoute } from '@angular/router'; +import { LANG } from '../translate.component'; +import { NotificationService } from '../notification.service'; declare function $j(selector: any) : any; -declare function successNotification(message: string) : void; -declare function errorNotification(message: string) : void; declare var angularGlobals : any; + @Component({ templateUrl : angularGlobals['status-administrationView'], - styleUrls : ['../../node_modules/bootstrap/dist/css/bootstrap.min.css', 'css/status-administration.component.css'] + styleUrls : ['css/status-administration.component.css'], + providers : [NotificationService] }) export class StatusAdministrationComponent implements OnInit { coreUrl : string; - pageTitle : string = "" ; - mode : string = null; + lang : any = LANG; + + creationMode : boolean; + statusIdentifier : string; status : any = { id : null, - label_status : null, + label_status : null, can_be_searched : null, can_be_modified : null, - is_folder_status : null, - img_filename : null + is_folder_status: null, + img_filename : null }; - lang : any = ""; statusImages : any = ""; loading : boolean = false; - constructor(public http: HttpClient, private route: ActivatedRoute, private router: Router) { + constructor(public http: HttpClient, private route: ActivatedRoute, private router: Router, private notify: NotificationService) { } ngOnInit(): void { this.loading = true; this.coreUrl = angularGlobals.coreUrl; + this.prepareStatus(); this.route.params.subscribe((params) => { if (typeof params['identifier'] == "undefined"){ this.http.get(this.coreUrl + 'rest/administration/status/new') .subscribe((data) => { - this.lang = data['lang']; + this.status.img_filename = "fm-letter"; + this.status.can_be_searched = true + this.status.can_be_modified = true this.statusImages = data['statusImages']; - this.mode = 'create'; - this.pageTitle = this.lang.newStatus; + this.creationMode = true; this.updateBreadcrumb(angularGlobals.applicationName); + this.loading = false; }); } else { - this.mode = 'update'; + this.creationMode = false; this.statusIdentifier = params['identifier']; this.getStatusInfos(this.statusIdentifier); + this.loading = false; } - setTimeout(() => { - $j(".help").tooltipster({ - theme: 'tooltipster-maarch', - interactive: true - }); - }, 0); }); - this.loading = false; } prepareStatus() { @@ -69,12 +69,12 @@ export class StatusAdministrationComponent implements OnInit { updateBreadcrumb(applicationName: string){ var breadCrumb = "<a href='index.php?reinit=true'>" + applicationName + "</a> > "+ - "<a onclick='location.hash = \"/administration\"' style='cursor: pointer'>"+this.lang.admin+"</a> > "+ - "<a onclick='location.hash = \"/administration/status\"' style='cursor: pointer'>"+this.lang.admin_status+"</a> > "; - if(this.mode == 'create'){ - breadCrumb += this.lang.newItem; + "<a onclick='location.hash = \"/administration\"' style='cursor: pointer'>"+this.lang.administration+"</a> > "+ + "<a onclick='location.hash = \"/administration/status\"' style='cursor: pointer'>"+this.lang.statuses+"</a> > "; + if(this.creationMode == true){ + breadCrumb += this.lang.statusCreation; } else { - breadCrumb += this.lang.modification; + breadCrumb += this.lang.statusModification; } $j('#ariane')[0].innerHTML = breadCrumb; } @@ -98,36 +98,30 @@ export class StatusAdministrationComponent implements OnInit { }else{ this.status.is_folder_status = false; } - this.lang = data['lang']; this.statusImages = data['statusImages']; - this.pageTitle = this.lang.modify_status + ' : ' + this.status.id; this.updateBreadcrumb(angularGlobals.applicationName); }, (err) => { - errorNotification(JSON.parse(err._body).errors); + this.notify.error(JSON.parse(err._body).errors); }); } - - selectImage(image_name : string){ - this.status.img_filename = image_name; - } submitStatus() { - if(this.mode == 'create'){ + if(this.creationMode == true){ this.http.post(this.coreUrl + 'rest/status', this.status) - .subscribe(() => { - successNotification(this.lang.newStatusAdded + ' : ' + this.status.id); + .subscribe((data : any) => { + this.notify.success(this.lang.statusAdded+' « '+data.status.id+' »'); this.router.navigate(['administration/status']); }, (err) => { - errorNotification((JSON.parse(err._body).errors).join("<br>")); + this.notify.error(JSON.parse(err._body).errors); }); - } else if(this.mode == "update"){ + } else if(this.creationMode == false){ this.http.put(this.coreUrl+'rest/status/'+this.statusIdentifier, this.status) - .subscribe(() => { - successNotification(this.lang.statusUpdated + ' : ' + this.status.id); + .subscribe((data : any) => { + this.notify.success(this.lang.statusUpdated+' « '+data.status.id+' »'); this.router.navigate(['administration/status']); }, (err) => { - errorNotification((JSON.parse(err._body).errors).join("<br>")); + this.notify.error(JSON.parse(err._body).errors); }); } } diff --git a/apps/maarch_entreprise/js/angular/app/administration/statuses-administration.component.js b/apps/maarch_entreprise/js/angular/app/administration/statuses-administration.component.js index d200a51aa207c09c7125853b0976b70d390c6671..0dc14ca5b9c0e89bac73c4db93d92e89c621a6a9 100755 --- a/apps/maarch_entreprise/js/angular/app/administration/statuses-administration.component.js +++ b/apps/maarch_entreprise/js/angular/app/administration/statuses-administration.component.js @@ -11,11 +11,14 @@ var __metadata = (this && this.__metadata) || function (k, v) { Object.defineProperty(exports, "__esModule", { value: true }); var core_1 = require("@angular/core"); var http_1 = require("@angular/common/http"); +var translate_component_1 = require("../translate.component"); +var notification_service_1 = require("../notification.service"); var StatusesAdministrationComponent = (function () { - function StatusesAdministrationComponent(http) { + function StatusesAdministrationComponent(http, notify) { this.http = http; - this.lang = ""; - this.resultInfo = ""; + this.notify = notify; + this.lang = translate_component_1.LANG; + this.data = []; this.loading = false; } StatusesAdministrationComponent.prototype.ngOnInit = function () { @@ -26,42 +29,14 @@ var StatusesAdministrationComponent = (function () { this.http.get(this.coreUrl + 'rest/administration/status') .subscribe(function (data) { _this.statusList = data.statusList; - _this.lang = data.lang; - _this.nbStatus = Object.keys(_this.statusList).length; + _this.data = _this.statusList; setTimeout(function () { - _this.table = $j('#statusTable').DataTable({ - "dom": '<"datatablesLeft"p><"datatablesRight"f><"datatablesCenter"l>rt<"datatablesCenter"i><"clear">', - "lengthMenu": [10, 25, 50, 75, 100], - "oLanguage": { - "sLengthMenu": "<i class='fa fa-bars'></i> _MENU_", - "sZeroRecords": _this.lang.noResult, - "sInfo": "_START_ - _END_ / _TOTAL_ " + _this.lang.record, - "sSearch": "", - "oPaginate": { - "sFirst": "<<", - "sLast": ">>", - "sNext": _this.lang.next + " <i class='fa fa-caret-right'></i>", - "sPrevious": "<i class='fa fa-caret-left'></i> " + _this.lang.previous - }, - "sInfoEmpty": _this.lang.noRecord, - "sInfoFiltered": "(filtré de _MAX_ " + _this.lang.record + ")" - }, - "order": [[2, "asc"]], - "columnDefs": [ - { "orderable": false, "targets": [0, 3] } - ], - "stateSave": true - }); - $j('.dataTables_filter input').attr("placeholder", _this.lang.search); - $j('dataTables_filter input').addClass('form-control'); - $j(".datatablesLeft").css({ "float": "left" }); - $j(".datatablesCenter").css({ "text-align": "center" }); - $j(".datatablesRight").css({ "float": "right" }); + $j("[md2sortby='label_status']").click(); }, 0); _this.updateBreadcrumb(angularGlobals.applicationName); _this.loading = false; }, function (err) { - errorNotification(JSON.parse(err._body).errors); + _this.notify.error(JSON.parse(err._body).errors); }); }; StatusesAdministrationComponent.prototype.prepareStatus = function () { @@ -69,25 +44,18 @@ var StatusesAdministrationComponent = (function () { }; StatusesAdministrationComponent.prototype.updateBreadcrumb = function (applicationName) { $j('#ariane')[0].innerHTML = "<a href='index.php?reinit=true'>" + applicationName + "</a> > " + - "<a onclick='location.hash = \"/administration\"' style='cursor: pointer'>" + this.lang.admin + "</a> > " + this.lang.admin_status; + "<a onclick='location.hash = \"/administration\"' style='cursor: pointer'>" + this.lang.administration + "</a> > " + this.lang.statuses; }; - StatusesAdministrationComponent.prototype.deleteStatus = function (statusId, statusIdentifier) { + StatusesAdministrationComponent.prototype.deleteStatus = function (status) { var _this = this; - var resp = confirm(this.lang.deleteConfirm + ' ' + statusId + '?'); + var resp = confirm(this.lang.confirmAction + ' ' + this.lang.delete + ' « ' + status.id + ' »'); if (resp) { - this.http.delete(this.coreUrl + 'rest/status/' + statusIdentifier) - .subscribe(function () { - var list = _this.statusList; - for (var i = 0; i < list.length; i++) { - if (list[i].id == statusId) { - list.splice(i, 1); - } - } - _this.table.row($j("#" + statusId)).remove().draw(); - successNotification(_this.lang.delStatus + " : " + statusId); - _this.nbStatus = Object.keys(_this.statusList).length; + this.http.delete(this.coreUrl + 'rest/status/' + status.identifier) + .subscribe(function (data) { + _this.data = data.statuses; + _this.notify.success(_this.lang.statusDeleted + ' « ' + status.id + ' »'); }, function (err) { - errorNotification(JSON.parse(err._body).errors); + _this.notify.error(JSON.parse(err._body).errors); }); } }; @@ -96,8 +64,9 @@ var StatusesAdministrationComponent = (function () { StatusesAdministrationComponent = __decorate([ core_1.Component({ templateUrl: angularGlobals['statuses-administrationView'], - styleUrls: ['../../node_modules/bootstrap/dist/css/bootstrap.min.css'] + styleUrls: [], + providers: [notification_service_1.NotificationService] }), - __metadata("design:paramtypes", [http_1.HttpClient]) + __metadata("design:paramtypes", [http_1.HttpClient, notification_service_1.NotificationService]) ], StatusesAdministrationComponent); exports.StatusesAdministrationComponent = StatusesAdministrationComponent; diff --git a/apps/maarch_entreprise/js/angular/app/administration/statuses-administration.component.ts b/apps/maarch_entreprise/js/angular/app/administration/statuses-administration.component.ts index 18f0618ff55aba2396da017b877f0c8aa2578a5d..719fef1e1b0f3949bbff6d982e11c1255afcce41 100755 --- a/apps/maarch_entreprise/js/angular/app/administration/statuses-administration.component.ts +++ b/apps/maarch_entreprise/js/angular/app/administration/statuses-administration.component.ts @@ -1,29 +1,30 @@ import { Component, OnInit } from '@angular/core'; import { HttpClient } from '@angular/common/http'; import { Router, ActivatedRoute } from '@angular/router'; +import { LANG } from '../translate.component'; +import { NotificationService } from '../notification.service'; declare function $j(selector: any) : any; -declare function successNotification(message: string) : void; -declare function errorNotification(message: string) : void; declare var angularGlobals : any; @Component({ templateUrl : angularGlobals['statuses-administrationView'], - styleUrls : ['../../node_modules/bootstrap/dist/css/bootstrap.min.css'] + styleUrls : [], + providers : [NotificationService] }) export class StatusesAdministrationComponent implements OnInit { coreUrl : string; + lang : any = LANG; + nbStatus : number; - lang : any = ""; - table : any; statusList : any; + data : any = []; - resultInfo : string = ""; - loading : boolean = false; + loading : boolean = false; - constructor(public http: HttpClient) { + constructor(public http: HttpClient, private notify: NotificationService) { } ngOnInit(): void { @@ -36,43 +37,14 @@ export class StatusesAdministrationComponent implements OnInit { this.http.get(this.coreUrl + 'rest/administration/status') .subscribe((data : any) => { this.statusList = data.statusList; - this.lang = data.lang; - this.nbStatus = Object.keys(this.statusList).length; + this.data = this.statusList; setTimeout(() => { - this.table = $j('#statusTable').DataTable({ - "dom": '<"datatablesLeft"p><"datatablesRight"f><"datatablesCenter"l>rt<"datatablesCenter"i><"clear">', - "lengthMenu": [ 10, 25, 50, 75, 100 ], - "oLanguage": { - "sLengthMenu": "<i class='fa fa-bars'></i> _MENU_", - "sZeroRecords": this.lang.noResult, - "sInfo": "_START_ - _END_ / _TOTAL_ "+this.lang.record, - "sSearch": "", - "oPaginate": { - "sFirst": "<<", - "sLast": ">>", - "sNext": this.lang.next+" <i class='fa fa-caret-right'></i>", - "sPrevious": "<i class='fa fa-caret-left'></i> "+this.lang.previous - }, - "sInfoEmpty": this.lang.noRecord, - "sInfoFiltered": "(filtré de _MAX_ "+this.lang.record+")" - }, - "order": [[ 2, "asc" ]], - "columnDefs": [ - { "orderable": false, "targets": [0,3] } - ], - "stateSave": true - }); - $j('.dataTables_filter input').attr("placeholder", this.lang.search); - $j('dataTables_filter input').addClass('form-control'); - $j(".datatablesLeft").css({"float":"left"}); - $j(".datatablesCenter").css({"text-align":"center"}); - $j(".datatablesRight").css({"float":"right"}); - + $j("[md2sortby='label_status']").click(); }, 0); this.updateBreadcrumb(angularGlobals.applicationName); this.loading = false; }, (err) => { - errorNotification(JSON.parse(err._body).errors); + this.notify.error(JSON.parse(err._body).errors); }); } @@ -82,26 +54,19 @@ export class StatusesAdministrationComponent implements OnInit { updateBreadcrumb(applicationName: string){ $j('#ariane')[0].innerHTML = "<a href='index.php?reinit=true'>" + applicationName + "</a> > "+ - "<a onclick='location.hash = \"/administration\"' style='cursor: pointer'>" + this.lang.admin + "</a> > " + this.lang.admin_status; + "<a onclick='location.hash = \"/administration\"' style='cursor: pointer'>" + this.lang.administration + "</a> > " + this.lang.statuses; } - deleteStatus(statusId : string, statusIdentifier : string){ - var resp = confirm(this.lang.deleteConfirm+' '+statusId+'?'); + deleteStatus(status : any){ + var resp = confirm(this.lang.confirmAction+' '+this.lang.delete+' « '+status.id+' »'); if(resp){ - this.http.delete(this.coreUrl + 'rest/status/'+statusIdentifier) - .subscribe(() => { - var list = this.statusList; - for(var i = 0; i<list.length;i++){ - if(list[i].id==statusId){ - list.splice(i, 1); - } - } - this.table.row($j("#"+statusId)).remove().draw(); - - successNotification(this.lang.delStatus + " : " + statusId); - this.nbStatus = Object.keys(this.statusList).length; + this.http.delete(this.coreUrl + 'rest/status/'+status.identifier) + .subscribe((data : any) => { + this.data = data.statuses; + this.notify.success(this.lang.statusDeleted+' « '+status.id+' »'); + }, (err) => { - errorNotification(JSON.parse(err._body).errors); + this.notify.error(JSON.parse(err._body).errors); }); } } diff --git a/apps/maarch_entreprise/js/angular/app/administration/user-administration.component.js b/apps/maarch_entreprise/js/angular/app/administration/user-administration.component.js index b149172318c3cf84febee1e7037531718e48f6b0..85fae090b052141017784cdf55f7cd22f199e550 100755 --- a/apps/maarch_entreprise/js/angular/app/administration/user-administration.component.js +++ b/apps/maarch_entreprise/js/angular/app/administration/user-administration.component.js @@ -13,14 +13,17 @@ var core_1 = require("@angular/core"); var http_1 = require("@angular/common/http"); var router_1 = require("@angular/router"); var translate_component_1 = require("../translate.component"); +var notification_service_1 = require("../notification.service"); var UserAdministrationComponent = (function () { - function UserAdministrationComponent(http, route, router, zone) { + function UserAdministrationComponent(http, route, router, zone, notify) { var _this = this; this.http = http; this.route = route; this.router = router; this.zone = zone; + this.notify = notify; this.lang = translate_component_1.LANG; + this._search = ''; this.user = {}; this.signatureModel = { base64: "", @@ -31,56 +34,101 @@ var UserAdministrationComponent = (function () { label: "", }; this.userAbsenceModel = []; + this.userList = []; this.selectedSignature = -1; this.selectedSignatureLabel = ""; + this.data = []; this.loading = false; window['angularUserAdministrationComponent'] = { componentAfterUpload: function (base64Content) { return _this.processAfterUpload(base64Content); }, }; } UserAdministrationComponent.prototype.updateBreadcrumb = function (applicationName) { - if ($j('#ariane')[0]) { - $j('#ariane')[0].innerHTML = "<a href='index.php?reinit=true'>" + applicationName + "</a> > <a onclick='location.hash = \"/administration\"' style='cursor: pointer'>Administration</a> > <a onclick='location.hash = \"/administration/users\"' style='cursor: pointer'>Utilisateurs</a>"; + var breadCrumb = "<a href='index.php?reinit=true'>" + applicationName + "</a> > <a onclick='location.hash = \"/administration\"' style='cursor: pointer'>" + this.lang.administration + "</a> > <a onclick='location.hash = \"/administration/users\"' style='cursor: pointer'>" + this.lang.users + "</a> > "; + if (this.creationMode == true) { + breadCrumb += this.lang.userCreation; } + else { + breadCrumb += this.lang.userModification; + } + $j('#ariane')[0].innerHTML = breadCrumb; }; UserAdministrationComponent.prototype.ngOnInit = function () { var _this = this; - this.updateBreadcrumb(angularGlobals.applicationName); + //$j('#header').remove(); this.coreUrl = angularGlobals.coreUrl; this.loading = true; this.route.params.subscribe(function (params) { if (typeof params['id'] == "undefined") { - _this.userCreation = true; + _this.creationMode = true; _this.loading = false; + _this.updateBreadcrumb(angularGlobals.applicationName); } else { - _this.userCreation = false; + _this.creationMode = false; _this.serialId = params['id']; _this.http.get(_this.coreUrl + "rest/users/" + _this.serialId + "/details") .subscribe(function (data) { _this.user = data; + _this.data = data.history; _this.userId = data.user_id; + _this.updateBreadcrumb(angularGlobals.applicationName); _this.loading = false; - setTimeout(function () { - $j("#absenceUser").typeahead({ - order: "asc", - display: "formattedUser", - templateValue: "{{user_id}}", - source: { - ajax: { - type: "GET", - dataType: "json", - url: _this.coreUrl + "rest/users/autocompleter", - } - } - }); - }, 0); }, function () { location.href = "index.php"; }); } }); }; + UserAdministrationComponent.prototype.toogleRedirect = function (basket) { + var _this = this; + $j('#redirectUser_' + basket.group_id + '_' + basket.basket_id).toggle(); + this.http.get(this.coreUrl + 'rest/administration/users') + .subscribe(function (data) { + _this.userList = data['users']; + }, function () { + location.href = "index.php"; + }); + }; + UserAdministrationComponent.prototype.initService = function () { + var _this = this; + if ($j('.jstree-container-ul').length == 0) { + $j('#jstree').jstree({ + "checkbox": { + "three_state": false //no cascade selection + }, + 'core': { + 'themes': { + 'name': 'proton', + 'responsive': true + }, + 'data': this.user.allEntities + }, + "plugins": ["checkbox", "search"] + }); + $j('#jstree') + .on('select_node.jstree', function (e, data) { + _this.addEntity(data.node.id); + }).on('deselect_node.jstree', function (e, data) { + console.log(data.node.id); + _this.deleteEntity(data.node.id); + }) + .jstree(); + var to = false; + $j('#jstree_search').keyup(function () { + if (to) { + clearTimeout(to); + } + to = setTimeout(function () { + var v = $j('#jstree_search').val(); + $j('#jstree').jstree(true).search(v); + }, 250); + }); + } + if ($j("[md2sortby='event_date']").length != 0) { + $j("[md2sortby='event_date']").click(); + } + }; UserAdministrationComponent.prototype.processAfterUpload = function (b64Content) { var _this = this; this.zone.run(function () { return _this.resfreshUpload(b64Content); }); @@ -96,13 +144,14 @@ var UserAdministrationComponent = (function () { this.signatureModel.type = ""; this.signatureModel.base64 = ""; this.signatureModel.base64ForJs = ""; - errorNotification("Taille maximum de fichier dépassée (2 MB)"); + this.notify.error("Taille maximum de fichier dépassée (2 MB)"); } }; UserAdministrationComponent.prototype.clickOnUploader = function (id) { $j('#' + id).click(); }; UserAdministrationComponent.prototype.uploadSignatureTrigger = function (fileInput) { + var _this = this; if (fileInput.target.files && fileInput.target.files[0]) { var reader = new FileReader(); this.signatureModel.name = fileInput.target.files[0].name; @@ -114,6 +163,7 @@ var UserAdministrationComponent = (function () { reader.readAsDataURL(fileInput.target.files[0]); reader.onload = function (value) { window['angularUserAdministrationComponent'].componentAfterUpload(value.target.result); + _this.submitSignature(); }; } }; @@ -121,85 +171,77 @@ var UserAdministrationComponent = (function () { this.selectedSignature = index; this.selectedSignatureLabel = this.user.signatures[index].signature_label; }; - UserAdministrationComponent.prototype.resetPassword = function () { - var r = confirm('Voulez-vous vraiment réinitialiser le mot de passe de l\'utilisateur ?'); + UserAdministrationComponent.prototype.resetPassword = function (user) { + var _this = this; + var r = confirm(this.lang.confirmAction + ' ' + this.lang.resetPsw); if (r) { this.http.put(this.coreUrl + "rest/users/" + this.serialId + "/password", {}) .subscribe(function (data) { - successNotification(data.success); + _this.notify.success(_this.lang.pswReseted + ' ' + _this.lang.for + ' « ' + user.user_id + ' »'); }, function (err) { - errorNotification(err.error.errors); + _this.notify.error(err.error.errors); }); } }; - UserAdministrationComponent.prototype.addGroup = function () { + UserAdministrationComponent.prototype.toggleGroup = function (group) { var _this = this; - var index = $j("#groupsSelect option:selected").index(); - if (index > 0) { - var group = { - "groupId": this.user.allGroups[index - 1].group_id, - "role": $j("#groupRole")[0].value + if ($j('#' + group.group_id + '-input').is(':checked') == true) { + var groupReq = { + "groupId": group.group_id, + "role": group.role }; - this.http.post(this.coreUrl + "rest/users/" + this.serialId + "/groups", group) + this.http.post(this.coreUrl + "rest/users/" + this.serialId + "/groups", groupReq) .subscribe(function (data) { _this.user.groups = data.groups; _this.user.allGroups = data.allGroups; - $j("#groupRole")[0].value = ""; - $j('#addGroupModal').modal('hide'); - successNotification(data.success); + _this.user.baskets = data.baskets; + _this.notify.success(_this.lang.groupAdded + ' « ' + group.group_id + ' »'); }, function (err) { - errorNotification(err.error.errors); + _this.notify.error(err.error.errors); }); } - }; - UserAdministrationComponent.prototype.updateGroup = function (group) { - this.http.put(this.coreUrl + "rest/users/" + this.serialId + "/groups/" + group.group_id, group) - .subscribe(function (data) { - successNotification(data.success); - }, function (err) { - errorNotification(err.error.errors); - }); - }; - UserAdministrationComponent.prototype.deleteGroup = function (group) { - var _this = this; - var r = confirm('Voulez-vous vraiment retirer l\'utilisateur de ce groupe ?'); - if (r) { + else { this.http.delete(this.coreUrl + "rest/users/" + this.serialId + "/groups/" + group.group_id) .subscribe(function (data) { _this.user.groups = data.groups; _this.user.allGroups = data.allGroups; - successNotification(data.success); + _this.notify.success(_this.lang.groupDeleted + ' « ' + group.group_id + ' »'); }, function (err) { - errorNotification(err.error.errors); + _this.notify.error(err.error.errors); }); } }; - UserAdministrationComponent.prototype.addEntity = function () { + UserAdministrationComponent.prototype.updateGroup = function (group) { var _this = this; - var index = $j("#entitiesSelect option:selected").index(); - if (index > 0) { - var entity = { - "entityId": this.user.allEntities[index - 1].entity_id, - "role": $j("#entityRole")[0].value - }; - this.http.post(this.coreUrl + "rest/users/" + this.serialId + "/entities", entity) - .subscribe(function (data) { - _this.user.entities = data.entities; - _this.user.allEntities = data.allEntities; - $j("#entityRole")[0].value = ""; - $j('#addEntityModal').modal('hide'); - successNotification(data.success); - }, function (err) { - errorNotification(err.error.errors); - }); - } + this.http.put(this.coreUrl + "rest/users/" + this.serialId + "/groups/" + group.group_id, group) + .subscribe(function (data) { + _this.notify.success(_this.lang.groupUpdated + ' « ' + group.group_id + ' »'); + }, function (err) { + _this.notify.error(err.error.errors); + }); + }; + UserAdministrationComponent.prototype.addEntity = function (entiyId) { + var _this = this; + var entity = { + "entityId": entiyId, + "role": '' + }; + this.http.post(this.coreUrl + "rest/users/" + this.serialId + "/entities", entity) + .subscribe(function (data) { + _this.user.entities = data.entities; + _this.user.allEntities = data.allEntities; + _this.notify.success(_this.lang.entityAdded + ' « ' + entiyId + ' »'); + }, function (err) { + _this.notify.error(err.error.errors); + }); }; UserAdministrationComponent.prototype.updateEntity = function (entity) { + var _this = this; this.http.put(this.coreUrl + "rest/users/" + this.serialId + "/entities/" + entity.entity_id, entity) .subscribe(function (data) { - successNotification(data.success); + _this.notify.success(_this.lang.entityUpdated + ' « ' + entity.entity_id + ' »'); }, function (err) { - errorNotification(err.error.errors); + _this.notify.error(err.error.errors); }); }; UserAdministrationComponent.prototype.updatePrimaryEntity = function (entity) { @@ -207,30 +249,28 @@ var UserAdministrationComponent = (function () { this.http.put(this.coreUrl + "rest/users/" + this.serialId + "/entities/" + entity.entity_id + "/primaryEntity", {}) .subscribe(function (data) { _this.user['entities'] = data.entities; - successNotification(data.success); + _this.notify.success(_this.lang.entityTooglePrimary + ' « ' + entity.entity_id + ' »'); }, function (err) { - errorNotification(err.error.errors); + _this.notify.error(err.error.errors); }); }; - UserAdministrationComponent.prototype.deleteEntity = function (entity) { + UserAdministrationComponent.prototype.deleteEntity = function (entityId) { var _this = this; - var r = confirm('Voulez-vous vraiment retirer l\'utilisateur de cette entité ?'); - if (r) { - this.http.delete(this.coreUrl + "rest/users/" + this.serialId + "/entities/" + entity.entity_id) - .subscribe(function (data) { - _this.user.entities = data.entities; - _this.user.allEntities = data.allEntities; - successNotification(data.success); - }, function (err) { - errorNotification(err.error.errors); - }); - } + this.http.delete(this.coreUrl + "rest/users/" + this.serialId + "/entities/" + entityId) + .subscribe(function (data) { + _this.user.entities = data.entities; + _this.user.allEntities = data.allEntities; + _this.notify.success(_this.lang.entityDeleted + ' « ' + entityId + ' »'); + }, function (err) { + _this.notify.error(err.error.errors); + }); }; UserAdministrationComponent.prototype.submitSignature = function () { var _this = this; this.http.post(this.coreUrl + "rest/users/" + this.serialId + "/signatures", this.signatureModel) .subscribe(function (data) { _this.user.signatures = data.signatures; + _this.notify.success(_this.lang.signAdded + ' « ' + _this.signatureModel.name + ' »'); _this.signatureModel = { base64: "", base64ForJs: "", @@ -239,56 +279,53 @@ var UserAdministrationComponent = (function () { size: 0, label: "", }; - successNotification(data.success); }, function (err) { - errorNotification(err.error.errors); + _this.notify.error(err.error.errors); }); }; - UserAdministrationComponent.prototype.updateSignature = function () { + UserAdministrationComponent.prototype.updateSignature = function (selectedSignature) { var _this = this; - var id = this.user.signatures[this.selectedSignature].id; - this.http.put(this.coreUrl + "rest/users/" + this.serialId + "/signatures/" + id, { "label": this.selectedSignatureLabel }) + var id = this.user.signatures[selectedSignature].id; + var label = this.user.signatures[selectedSignature].signature_label; + this.http.put(this.coreUrl + "rest/users/" + this.serialId + "/signatures/" + id, { "label": label }) .subscribe(function (data) { - _this.user.signatures[_this.selectedSignature].signature_label = data.signature.signature_label; - _this.selectedSignature = -1; - _this.selectedSignatureLabel = ""; - successNotification(data.success); + _this.user.signatures[selectedSignature].signature_label = data.signature.signature_label; + _this.notify.success(_this.lang.signUpdated + ' « ' + data.signature.signature_label + ' »'); }, function (err) { - errorNotification(err.error.errors); + _this.notify.error(err.error.errors); }); }; - UserAdministrationComponent.prototype.deleteSignature = function (id) { + UserAdministrationComponent.prototype.deleteSignature = function (signature) { var _this = this; - var r = confirm('Voulez-vous vraiment supprimer la signature ?'); + var r = confirm(this.lang.confirmAction + ' ' + this.lang.delete + ' « ' + signature.signature_label + ' »'); if (r) { - this.http.delete(this.coreUrl + "rest/users/" + this.serialId + "/signatures/" + id) + this.http.delete(this.coreUrl + "rest/users/" + this.serialId + "/signatures/" + signature.id) .subscribe(function (data) { _this.user.signatures = data.signatures; - successNotification(data.success); + _this.notify.success(_this.lang.signDeleted + ' « ' + signature.signature_label + ' »'); }, function (err) { - errorNotification(err.error.errors); + _this.notify.error(err.error.errors); }); } }; - UserAdministrationComponent.prototype.addBasketRedirection = function () { - var index = $j("#selectBasketAbsenceUser option:selected").index(); - if (index > 0 && $j("#absenceUser")[0].value != "") { + UserAdministrationComponent.prototype.addBasketRedirection = function (i, basket) { + var r = false; + if (this.user.status != 'ABS') { + var r_1 = confirm(this.lang.confirmAction + ' ' + this.lang.activateAbs); + } + if (r || this.user.status == 'ABS') { this.userAbsenceModel.push({ - "basketId": this.user.baskets[index - 1].basket_id, - "basketName": this.user.baskets[index - 1].basket_name, - "virtual": this.user.baskets[index - 1].is_virtual, - "basketOwner": this.user.baskets[index - 1].basket_owner, - "newUser": $j("#absenceUser")[0].value, - "index": index - 1 + "basketId": this.user.baskets[i].basket_id, + "basketName": this.user.baskets[i].basket_name, + "virtual": this.user.baskets[i].is_virtual, + "basketOwner": this.user.baskets[i].basket_owner, + "newUser": this.user.baskets[i].userToDisplay }); - this.user.baskets[index - 1].disabled = true; - $j('#selectBasketAbsenceUser option:eq(0)').prop("selected", true); - $j("#absenceUser")[0].value = ""; + this.activateAbsence(); } }; - UserAdministrationComponent.prototype.delBasketRedirection = function (index) { - this.user.baskets[this.userAbsenceModel[index].index].disabled = false; - this.userAbsenceModel.splice(index, 1); + UserAdministrationComponent.prototype.delBasketRedirection = function (i) { + this.user.baskets[i].userToDisplay = ''; }; UserAdministrationComponent.prototype.activateAbsence = function () { var _this = this; @@ -296,39 +333,41 @@ var UserAdministrationComponent = (function () { .subscribe(function (data) { _this.user.status = data.user.status; _this.userAbsenceModel = []; - $j('#manageAbs').modal('hide'); - successNotification(data.success); + _this.notify.success(_this.lang.absOn + ' ' + _this.lang.for + ' « ' + _this.user.user_id + ' »'); }, function (err) { - errorNotification(err.error.errors); + _this.notify.error(err.error.errors); }); }; - UserAdministrationComponent.prototype.deactivateAbsence = function () { + UserAdministrationComponent.prototype.desactivateAbsence = function () { var _this = this; this.http.put(this.coreUrl + "rest/users/" + this.serialId + "/status", { "status": "OK" }) .subscribe(function (data) { _this.user.status = data.user.status; - successNotification(data.success); + for (var i in _this.user.baskets) { + _this.user.baskets[i].userToDisplay = ''; + } + _this.notify.success(_this.lang.absOff + ' ' + _this.lang.for + ' « ' + _this.user.user_id + ' »'); }, function (err) { - errorNotification(err.error.errors); + _this.notify.error(err.error.errors); }); }; UserAdministrationComponent.prototype.onSubmit = function () { var _this = this; - if (this.userCreation) { + if (this.creationMode) { this.http.post(this.coreUrl + "rest/users", this.user) .subscribe(function (data) { - successNotification(data.success); + _this.notify.success(_this.lang.userAdded + ' « ' + data.user.user_id + ' »'); _this.router.navigate(["/administration/users/" + data.user.id]); }, function (err) { - errorNotification(err.error.errors); + _this.notify.error(err.error.errors); }); } else { this.http.put(this.coreUrl + "rest/users/" + this.serialId, this.user) .subscribe(function (data) { - successNotification(data.success); + _this.notify.success(_this.lang.userUpdated + ' « ' + _this.user.user_id + ' »'); }, function (err) { - errorNotification(err.error.errors); + _this.notify.error(err.error.errors); }); } }; @@ -337,8 +376,9 @@ var UserAdministrationComponent = (function () { UserAdministrationComponent = __decorate([ core_1.Component({ templateUrl: angularGlobals["user-administrationView"], - styleUrls: ['../../node_modules/bootstrap/dist/css/bootstrap.min.css', 'css/user-administration.component.css'] + styleUrls: ['css/user-administration.component.css'], + providers: [notification_service_1.NotificationService] }), - __metadata("design:paramtypes", [http_1.HttpClient, router_1.ActivatedRoute, router_1.Router, core_1.NgZone]) + __metadata("design:paramtypes", [http_1.HttpClient, router_1.ActivatedRoute, router_1.Router, core_1.NgZone, notification_service_1.NotificationService]) ], UserAdministrationComponent); exports.UserAdministrationComponent = UserAdministrationComponent; diff --git a/apps/maarch_entreprise/js/angular/app/administration/user-administration.component.ts b/apps/maarch_entreprise/js/angular/app/administration/user-administration.component.ts index 3f503996a9dd1f6cbc51d4146c5034c0ba61bd7c..922e9adc0fbcbe04399bbf90ce2da654a55638e8 100755 --- a/apps/maarch_entreprise/js/angular/app/administration/user-administration.component.ts +++ b/apps/maarch_entreprise/js/angular/app/administration/user-administration.component.ts @@ -2,25 +2,27 @@ import { Component, OnInit, NgZone } from '@angular/core'; import { HttpClient } from '@angular/common/http'; import { ActivatedRoute, Router } from '@angular/router'; import { LANG } from '../translate.component'; +import { NotificationService } from '../notification.service'; declare function $j(selector: any) : any; -declare function successNotification(message: string) : void; -declare function errorNotification(message: string) : void; declare const angularGlobals : any; @Component({ templateUrl : angularGlobals["user-administrationView"], - styleUrls : ['../../node_modules/bootstrap/dist/css/bootstrap.min.css', 'css/user-administration.component.css'] + styleUrls : ['css/user-administration.component.css'], + providers : [NotificationService] }) export class UserAdministrationComponent implements OnInit { coreUrl : string; lang : any = LANG; + _search : string = ''; + userId : string; serialId : number; - userCreation : boolean; + creationMode : boolean; user : any = {}; signatureModel : any = { @@ -32,57 +34,54 @@ export class UserAdministrationComponent implements OnInit { label : "", }; userAbsenceModel : any[] = []; - + userList : any[] = []; + selectedSignature : number = -1; selectedSignatureLabel : string = ""; + data : any = []; loading : boolean = false; - - constructor(public http: HttpClient, private route: ActivatedRoute, private router: Router, private zone: NgZone) { + constructor(public http: HttpClient, private route: ActivatedRoute, private router: Router, private zone: NgZone, private notify: NotificationService) { window['angularUserAdministrationComponent'] = { componentAfterUpload: (base64Content: any) => this.processAfterUpload(base64Content), }; + } updateBreadcrumb(applicationName: string) { - if ($j('#ariane')[0]) { - $j('#ariane')[0].innerHTML = "<a href='index.php?reinit=true'>" + applicationName + "</a> > <a onclick='location.hash = \"/administration\"' style='cursor: pointer'>Administration</a> > <a onclick='location.hash = \"/administration/users\"' style='cursor: pointer'>Utilisateurs</a>"; + var breadCrumb = "<a href='index.php?reinit=true'>" + applicationName + "</a> > <a onclick='location.hash = \"/administration\"' style='cursor: pointer'>"+this.lang.administration+"</a> > <a onclick='location.hash = \"/administration/users\"' style='cursor: pointer'>"+this.lang.users+"</a> > "; + + if(this.creationMode == true){ + breadCrumb += this.lang.userCreation; + } else { + breadCrumb += this.lang.userModification; } + $j('#ariane')[0].innerHTML = breadCrumb; } ngOnInit(): void { - this.updateBreadcrumb(angularGlobals.applicationName); + //$j('#header').remove(); this.coreUrl = angularGlobals.coreUrl; this.loading = true; this.route.params.subscribe(params => { if (typeof params['id'] == "undefined") { - this.userCreation = true; + this.creationMode = true; this.loading = false; + this.updateBreadcrumb(angularGlobals.applicationName); } else { - this.userCreation = false; + this.creationMode = false; this.serialId = params['id']; this.http.get(this.coreUrl + "rest/users/" + this.serialId + "/details") .subscribe((data : any) => { this.user = data; + this.data = data.history; this.userId = data.user_id; - + this.updateBreadcrumb(angularGlobals.applicationName); this.loading = false; - setTimeout(() => { - $j("#absenceUser").typeahead({ - order: "asc", - display: "formattedUser", - templateValue: "{{user_id}}", - source: { - ajax: { - type: "GET", - dataType: "json", - url: this.coreUrl + "rest/users/autocompleter", - } - } - }); - }, 0); + + }, () => { location.href = "index.php"; }); @@ -90,6 +89,58 @@ export class UserAdministrationComponent implements OnInit { }); } + toogleRedirect(basket:any) { + $j('#redirectUser_'+basket.group_id+'_'+basket.basket_id).toggle(); + + this.http.get(this.coreUrl + 'rest/administration/users') + .subscribe((data : any) => { + this.userList = data['users']; + + }, () => { + location.href = "index.php"; + }); + } + + initService(){ + if($j('.jstree-container-ul').length == 0){ + $j('#jstree').jstree({ + "checkbox" : { + "three_state" : false //no cascade selection + }, + 'core' : { + 'themes': { + 'name': 'proton', + 'responsive': true + }, + 'data' : this.user.allEntities + }, + "plugins" : [ "checkbox", "search" ] + }); + $j('#jstree') + // listen for event + .on('select_node.jstree', (e:any, data:any) => { + this.addEntity(data.node.id); + }).on('deselect_node.jstree', (e:any, data:any) => { + console.log(data.node.id); + this.deleteEntity(data.node.id); + }) + // create the instance + .jstree(); + + var to : any = false; + $j('#jstree_search').keyup(function () { + if(to) { clearTimeout(to); } + to = setTimeout(function () { + var v = $j('#jstree_search').val(); + $j('#jstree').jstree(true).search(v); + }, 250); + }); + } + if($j("[md2sortby='event_date']").length != 0){ + $j("[md2sortby='event_date']").click(); + } + } + processAfterUpload(b64Content: any) { this.zone.run(() => this.resfreshUpload(b64Content)); } @@ -105,7 +156,7 @@ export class UserAdministrationComponent implements OnInit { this.signatureModel.base64 = ""; this.signatureModel.base64ForJs = ""; - errorNotification("Taille maximum de fichier dépassée (2 MB)"); + this.notify.error("Taille maximum de fichier dépassée (2 MB)"); } } @@ -126,10 +177,10 @@ export class UserAdministrationComponent implements OnInit { reader.readAsDataURL(fileInput.target.files[0]); - reader.onload = function (value: any) { + reader.onload = (value: any) => { window['angularUserAdministrationComponent'].componentAfterUpload(value.target.result); + this.submitSignature(); }; - } } @@ -138,93 +189,78 @@ export class UserAdministrationComponent implements OnInit { this.selectedSignatureLabel = this.user.signatures[index].signature_label; } - resetPassword() { - let r = confirm('Voulez-vous vraiment réinitialiser le mot de passe de l\'utilisateur ?'); + resetPassword(user:any) { + let r = confirm(this.lang.confirmAction+' '+this.lang.resetPsw); if (r) { this.http.put(this.coreUrl + "rest/users/" + this.serialId + "/password", {}) .subscribe((data : any) => { - successNotification(data.success); + this.notify.success(this.lang.pswReseted+' '+this.lang.for+' « '+user.user_id+' »'); }, (err) => { - errorNotification(err.error.errors); + this.notify.error(err.error.errors); }); } } - addGroup() { - var index = $j("#groupsSelect option:selected").index(); - - if (index > 0) { - var group = { - "groupId" : this.user.allGroups[index - 1].group_id, - "role" : $j("#groupRole")[0].value + toggleGroup(group: any){ + if($j('#'+group.group_id+'-input').is(':checked') == true){ + var groupReq = { + "groupId" : group.group_id, + "role" : group.role }; - - this.http.post(this.coreUrl + "rest/users/" + this.serialId + "/groups", group) - .subscribe((data : any) => { - this.user.groups = data.groups; - this.user.allGroups = data.allGroups; - $j("#groupRole")[0].value = ""; - $j('#addGroupModal').modal('hide'); - successNotification(data.success); - }, (err) => { - errorNotification(err.error.errors); - }); + this.http.post(this.coreUrl + "rest/users/" + this.serialId + "/groups", groupReq) + .subscribe((data : any) => { + this.user.groups = data.groups; + this.user.allGroups = data.allGroups; + this.user.baskets = data.baskets; + this.notify.success(this.lang.groupAdded+' « '+group.group_id+' »'); + }, (err) => { + this.notify.error(err.error.errors); + }); + }else{ + this.http.delete(this.coreUrl + "rest/users/" + this.serialId + "/groups/" + group.group_id) + .subscribe((data : any) => { + this.user.groups = data.groups; + this.user.allGroups = data.allGroups; + this.notify.success(this.lang.groupDeleted+' « '+group.group_id+' »'); + }, (err) => { + this.notify.error(err.error.errors); + }); } } - updateGroup(group: any) { this.http.put(this.coreUrl + "rest/users/" + this.serialId + "/groups/" + group.group_id, group) .subscribe((data : any) => { - successNotification(data.success); + this.notify.success(this.lang.groupUpdated+' « '+group.group_id+' »'); }, (err) => { - errorNotification(err.error.errors); + this.notify.error(err.error.errors); }); } - deleteGroup(group: any) { - let r = confirm('Voulez-vous vraiment retirer l\'utilisateur de ce groupe ?'); + addEntity(entiyId:any) { - if (r) { - this.http.delete(this.coreUrl + "rest/users/" + this.serialId + "/groups/" + group.group_id) - .subscribe((data : any) => { - this.user.groups = data.groups; - this.user.allGroups = data.allGroups; - successNotification(data.success); - }, (err) => { - errorNotification(err.error.errors); - }); - } - } - - addEntity() { - var index = $j("#entitiesSelect option:selected").index(); - - if (index > 0) { - var entity = { - "entityId" : this.user.allEntities[index - 1].entity_id, - "role" : $j("#entityRole")[0].value - }; + var entity = { + "entityId" : entiyId, + "role" : '' + }; - this.http.post(this.coreUrl + "rest/users/" + this.serialId + "/entities", entity) - .subscribe((data : any) => { - this.user.entities = data.entities; - this.user.allEntities = data.allEntities; - $j("#entityRole")[0].value = ""; - $j('#addEntityModal').modal('hide'); - successNotification(data.success); - }, (err) => { - errorNotification(err.error.errors); - }); - } + this.http.post(this.coreUrl + "rest/users/" + this.serialId + "/entities", entity) + .subscribe((data : any) => { + this.user.entities = data.entities; + this.user.allEntities = data.allEntities; + this.notify.success(this.lang.entityAdded+' « '+entiyId+' »'); + }, (err) => { + this.notify.error(err.error.errors); + }); + } updateEntity(entity: any) { this.http.put(this.coreUrl + "rest/users/" + this.serialId + "/entities/" + entity.entity_id, entity) .subscribe((data : any) => { - successNotification(data.success); + this.notify.success(this.lang.entityUpdated+' « '+entity.entity_id+' »'); }, (err) => { - errorNotification(err.error.errors); + this.notify.error(err.error.errors); }); } @@ -232,31 +268,30 @@ export class UserAdministrationComponent implements OnInit { this.http.put(this.coreUrl + "rest/users/" + this.serialId + "/entities/" + entity.entity_id + "/primaryEntity", {}) .subscribe((data : any) => { this.user['entities'] = data.entities; - successNotification(data.success); + this.notify.success(this.lang.entityTooglePrimary+' « '+entity.entity_id+' »'); }, (err) => { - errorNotification(err.error.errors); + this.notify.error(err.error.errors); }); } - deleteEntity(entity: any) { - let r = confirm('Voulez-vous vraiment retirer l\'utilisateur de cette entité ?'); + deleteEntity(entityId: any) { - if (r) { - this.http.delete(this.coreUrl + "rest/users/" + this.serialId + "/entities/" + entity.entity_id) - .subscribe((data : any) => { - this.user.entities = data.entities; - this.user.allEntities = data.allEntities; - successNotification(data.success); - }, (err) => { - errorNotification(err.error.errors); - }); - } + this.http.delete(this.coreUrl + "rest/users/" + this.serialId + "/entities/" + entityId) + .subscribe((data : any) => { + this.user.entities = data.entities; + this.user.allEntities = data.allEntities; + this.notify.success(this.lang.entityDeleted+' « '+entityId+' »'); + }, (err) => { + this.notify.error(err.error.errors); + }); + } submitSignature() { this.http.post(this.coreUrl + "rest/users/" + this.serialId + "/signatures", this.signatureModel) .subscribe((data : any) => { this.user.signatures = data.signatures; + this.notify.success(this.lang.signAdded+' « '+this.signatureModel.name+' »'); this.signatureModel = { base64 : "", base64ForJs : "", @@ -265,61 +300,58 @@ export class UserAdministrationComponent implements OnInit { size : 0, label : "", }; - successNotification(data.success); }, (err) => { - errorNotification(err.error.errors); + this.notify.error(err.error.errors); }); } - updateSignature() { - var id = this.user.signatures[this.selectedSignature].id; - - this.http.put(this.coreUrl + "rest/users/" + this.serialId + "/signatures/" + id, {"label" : this.selectedSignatureLabel}) + updateSignature(selectedSignature:any) { + var id = this.user.signatures[selectedSignature].id; + var label = this.user.signatures[selectedSignature].signature_label; + + this.http.put(this.coreUrl + "rest/users/" + this.serialId + "/signatures/" + id, {"label" : label}) .subscribe((data : any) => { - this.user.signatures[this.selectedSignature].signature_label = data.signature.signature_label; - this.selectedSignature = -1; - this.selectedSignatureLabel = ""; - successNotification(data.success); + this.user.signatures[selectedSignature].signature_label = data.signature.signature_label; + this.notify.success(this.lang.signUpdated+' « '+data.signature.signature_label+' »'); }, (err) => { - errorNotification(err.error.errors); + this.notify.error(err.error.errors); }); } - deleteSignature(id: number) { - let r = confirm('Voulez-vous vraiment supprimer la signature ?'); + deleteSignature(signature: any) { + let r = confirm(this.lang.confirmAction+' '+this.lang.delete+' « '+signature.signature_label+' »'); if (r) { - this.http.delete(this.coreUrl + "rest/users/" + this.serialId + "/signatures/" + id) + this.http.delete(this.coreUrl + "rest/users/" + this.serialId + "/signatures/" + signature.id) .subscribe((data : any) => { this.user.signatures = data.signatures; - successNotification(data.success); + this.notify.success(this.lang.signDeleted+' « '+signature.signature_label+' »'); }, (err) => { - errorNotification(err.error.errors); + this.notify.error(err.error.errors); }); } } - addBasketRedirection() { - var index = $j("#selectBasketAbsenceUser option:selected").index(); - - if (index > 0 && $j("#absenceUser")[0].value != "") { + addBasketRedirection(i:number,basket:any) { + let r = false; + if(this.user.status != 'ABS'){ + let r = confirm(this.lang.confirmAction+' '+this.lang.activateAbs); + } + + if (r || this.user.status == 'ABS') { this.userAbsenceModel.push({ - "basketId" : this.user.baskets[index - 1].basket_id, - "basketName" : this.user.baskets[index - 1].basket_name, - "virtual" : this.user.baskets[index - 1].is_virtual, - "basketOwner" : this.user.baskets[index - 1].basket_owner, - "newUser" : $j("#absenceUser")[0].value, - "index" : index - 1 + "basketId" : this.user.baskets[i].basket_id, + "basketName" : this.user.baskets[i].basket_name, + "virtual" : this.user.baskets[i].is_virtual, + "basketOwner" : this.user.baskets[i].basket_owner, + "newUser" : this.user.baskets[i].userToDisplay }); - this.user.baskets[index - 1].disabled = true; - $j('#selectBasketAbsenceUser option:eq(0)').prop("selected", true); - $j("#absenceUser")[0].value = ""; + this.activateAbsence(); } } - delBasketRedirection(index: number) { - this.user.baskets[this.userAbsenceModel[index].index].disabled = false; - this.userAbsenceModel.splice(index, 1); + delBasketRedirection(i:number) { + this.user.baskets[i].userToDisplay = ''; } activateAbsence() { @@ -327,38 +359,40 @@ export class UserAdministrationComponent implements OnInit { .subscribe((data : any) => { this.user.status = data.user.status; this.userAbsenceModel = []; - $j('#manageAbs').modal('hide'); - successNotification(data.success); + this.notify.success(this.lang.absOn+' '+this.lang.for+' « '+this.user.user_id+' »'); }, (err) => { - errorNotification(err.error.errors); + this.notify.error(err.error.errors); }); } - deactivateAbsence() { + desactivateAbsence() { this.http.put(this.coreUrl + "rest/users/" + this.serialId + "/status", {"status" : "OK"}) .subscribe((data : any) => { this.user.status = data.user.status; - successNotification(data.success); + for (let i in this.user.baskets) { + this.user.baskets[i].userToDisplay = ''; + } + this.notify.success(this.lang.absOff+' '+this.lang.for+' « '+this.user.user_id+' »'); }, (err) => { - errorNotification(err.error.errors); + this.notify.error(err.error.errors); }); } onSubmit() { - if (this.userCreation) { + if (this.creationMode) { this.http.post(this.coreUrl + "rest/users", this.user) .subscribe((data : any) => { - successNotification(data.success); + this.notify.success(this.lang.userAdded+' « '+data.user.user_id+' »'); this.router.navigate(["/administration/users/" + data.user.id]); }, (err) => { - errorNotification(err.error.errors); + this.notify.error(err.error.errors); }); } else { this.http.put(this.coreUrl + "rest/users/" + this.serialId, this.user) .subscribe((data : any) => { - successNotification(data.success); + this.notify.success(this.lang.userUpdated+' « '+this.user.user_id+' »'); }, (err) => { - errorNotification(err.error.errors); + this.notify.error(err.error.errors); }); } } diff --git a/apps/maarch_entreprise/js/angular/app/administration/users-administration.component.js b/apps/maarch_entreprise/js/angular/app/administration/users-administration.component.js index a3987ee0309c48feb0d8c2895a9deb72db9e9132..03c7bca00331c85884fe080133ec39370c0ff71b 100755 --- a/apps/maarch_entreprise/js/angular/app/administration/users-administration.component.js +++ b/apps/maarch_entreprise/js/angular/app/administration/users-administration.component.js @@ -11,19 +11,42 @@ var __metadata = (this && this.__metadata) || function (k, v) { Object.defineProperty(exports, "__esModule", { value: true }); var core_1 = require("@angular/core"); var http_1 = require("@angular/common/http"); +var translate_component_1 = require("../translate.component"); +var notification_service_1 = require("../notification.service"); +var DataTablePipe = (function () { + function DataTablePipe() { + } + DataTablePipe.prototype.transform = function (array, field, query) { + if (query) { + query = query.toLowerCase(); + console.log(array); + return array.filter(function (value) { + return value[field].toLowerCase().indexOf(query) > -1; + }); + } + return array; + }; + return DataTablePipe; +}()); +DataTablePipe = __decorate([ + core_1.Pipe({ name: 'dataPipe' }) +], DataTablePipe); +exports.DataTablePipe = DataTablePipe; var UsersAdministrationComponent = (function () { - function UsersAdministrationComponent(http) { + function UsersAdministrationComponent(http, notify) { this.http = http; + this.notify = notify; + this.search = null; this.users = []; this.userDestRedirect = {}; this.userDestRedirectModels = []; - this.lang = {}; - this.resultInfo = ""; + this.lang = translate_component_1.LANG; this.loading = false; + this.data = []; } UsersAdministrationComponent.prototype.updateBreadcrumb = function (applicationName) { if ($j('#ariane')[0]) { - $j('#ariane')[0].innerHTML = "<a href='index.php?reinit=true'>" + applicationName + "</a> > <a onclick='location.hash = \"/administration\"' style='cursor: pointer'>Administration</a> > Utilisateurs"; + $j('#ariane')[0].innerHTML = "<a href='index.php?reinit=true'>" + applicationName + "</a> > <a onclick='location.hash = \"/administration\"' style='cursor: pointer'>" + this.lang.administration + "</a> > " + this.lang.users; } }; UsersAdministrationComponent.prototype.ngOnInit = function () { @@ -34,37 +57,11 @@ var UsersAdministrationComponent = (function () { this.http.get(this.coreUrl + 'rest/administration/users') .subscribe(function (data) { _this.users = data['users']; - _this.lang = data.lang; + _this.data = _this.users; + _this.loading = false; setTimeout(function () { - _this.table = $j('#usersTable').DataTable({ - "dom": '<"datatablesLeft"p><"datatablesRight"f><"datatablesCenter"l>rt<"datatablesCenter"i><"clear">', - "lengthMenu": [10, 25, 50, 75, 100], - "oLanguage": { - "sLengthMenu": "<i class='fa fa-bars'></i> _MENU_", - "sZeroRecords": _this.lang.noResult, - "sInfo": "_START_ - _END_ / _TOTAL_ " + _this.lang.record, - "sSearch": "", - "oPaginate": { - "sFirst": "<<", - "sLast": ">>", - "sNext": _this.lang.next + " <i class='fa fa-caret-right'></i>", - "sPrevious": "<i class='fa fa-caret-left'></i> " + _this.lang.previous - }, - "sInfoEmpty": _this.lang.noRecord, - "sInfoFiltered": "(filtré de _MAX_ " + _this.lang.record + ")" - }, - "order": [[1, "asc"]], - "columnDefs": [ - { "orderable": false, "targets": [3, 5] } - ] - }); - $j('.dataTables_filter input').attr("placeholder", _this.lang.search); - $j('dataTables_filter input').addClass('form-control'); - $j(".datatablesLeft").css({ "float": "left" }); - $j(".datatablesCenter").css({ "text-align": "center" }); - $j(".datatablesRight").css({ "float": "right" }); + $j("[md2sortby='user_id']").click(); }, 0); - _this.loading = false; }, function () { location.href = "index.php"; }); @@ -77,42 +74,28 @@ var UsersAdministrationComponent = (function () { this.http.get(this.coreUrl + 'rest/listModels/itemId/' + user.user_id + '/itemMode/dest/objectType/entity_id') .subscribe(function (data) { _this.userDestRedirectModels = data.listModels; - setTimeout(function () { - $j(".redirectDest").typeahead({ - order: "asc", - display: "formattedUser", - templateValue: "{{user_id}}", - source: { - ajax: { - type: "GET", - dataType: "json", - url: _this.coreUrl + "rest/users/autocompleter/exclude/" + user.user_id, - } - } - }); - }, 0); }, function (err) { console.log(err); location.href = "index.php"; }); } else { - var r = confirm(this.lang.suspendMsg + " ?"); + var r = confirm(this.lang.confirmAction + ' ' + this.lang.suspend + ' « ' + user.user_id + ' »'); if (r) { user.enabled = 'N'; this.http.put(this.coreUrl + 'rest/users/' + user.id, user) .subscribe(function (data) { - successNotification(data.success); + _this.notify.success(_this.lang.userSuspended + ' « ' + user.user_id + ' »'); }, function (err) { user.enabled = 'Y'; - errorNotification(JSON.parse(err._body).errors); + _this.notify.error(JSON.parse(err._body).errors); }); } } }; UsersAdministrationComponent.prototype.suspendUserModal = function (user) { var _this = this; - var r = confirm(this.lang.suspendMsg + " ?"); + var r = confirm(this.lang.confirmAction + ' ' + this.lang.suspend + ' « ' + user.user_id + ' »'); if (r) { user.enabled = 'N'; user.redirectListModels = this.userDestRedirectModels; @@ -121,35 +104,36 @@ var UsersAdministrationComponent = (function () { .subscribe(function (data) { if (data.errors) { user.enabled = 'Y'; - errorNotification(data.errors); + _this.notify.error(data.errors); } else { //then suspend user - _this.http.put(_this.coreUrl + 'rest/users/' + user.user_id, user) + _this.http.put(_this.coreUrl + 'rest/users/' + user.id, user) .subscribe(function (data) { user.inDiffListDest = 'N'; $j('#changeDiffListDest').modal('hide'); - successNotification(data.success); + _this.notify.success(_this.lang.userSuspended + ' « ' + user.user_id + ' »'); }, function (err) { user.enabled = 'Y'; - errorNotification(JSON.parse(err._body).errors); + _this.notify.error(JSON.parse(err._body).errors); }); } }, function (err) { - errorNotification(JSON.parse(err._body).errors); + _this.notify.error(JSON.parse(err._body).errors); }); } }; UsersAdministrationComponent.prototype.activateUser = function (user) { - var r = confirm(this.lang.authorizeMsg + " ?"); + var _this = this; + var r = confirm(this.lang.confirmAction + ' ' + this.lang.authorize + ' « ' + user.user_id + ' »'); if (r) { user.enabled = 'Y'; this.http.put(this.coreUrl + 'rest/users/' + user.id, user) .subscribe(function (data) { - successNotification(data.success); + _this.notify.success(_this.lang.userAuthorized + ' « ' + user.user_id + ' »'); }, function (err) { user.enabled = 'N'; - errorNotification(JSON.parse(err._body).errors); + _this.notify.error(JSON.parse(err._body).errors); }); } }; @@ -161,70 +145,48 @@ var UsersAdministrationComponent = (function () { this.http.get(this.coreUrl + 'rest/listModels/itemId/' + user.user_id + '/itemMode/dest/objectType/entity_id') .subscribe(function (data) { _this.userDestRedirectModels = data.listModels; - setTimeout(function () { - $j(".redirectDest").typeahead({ - order: "asc", - source: { - ajax: { - type: "GET", - dataType: "json", - url: _this.coreUrl + "rest/users/autocompleter/exclude/" + user.user_id, - } - } - }); - }); }, function (err) { - errorNotification(JSON.parse(err._body).errors); + _this.notify.error(JSON.parse(err._body).errors); }); } else { - var r = confirm(this.lang.deleteMsg + " ?"); + var r = confirm(this.lang.confirmAction + ' ' + this.lang.delete + ' « ' + user.user_id + ' »'); if (r) { - this.http.delete(this.coreUrl + 'rest/users/' + user.user_id, user) + this.http.delete(this.coreUrl + 'rest/users/' + user.id, user) .subscribe(function (data) { - for (var i = 0; i < _this.users.length; i++) { - if (_this.users[i].user_id == user.user_id) { - _this.users.splice(i, 1); - } - } - _this.table.row($j("#" + user.user_id)).remove().draw(); - successNotification(data.success); + _this.data = data.users; + _this.notify.success(_this.lang.userDeleted + ' « ' + user.user_id + ' »'); }, function (err) { - errorNotification(JSON.parse(err._body).errors); + _this.notify.error(JSON.parse(err._body).errors); }); } } }; UsersAdministrationComponent.prototype.deleteUserModal = function (user) { var _this = this; - var r = confirm(this.lang.deleteMsg + " ?"); + var r = confirm(this.lang.confirmAction + ' ' + this.lang.delete + ' « ' + user.user_id + ' »'); if (r) { user.redirectListModels = this.userDestRedirectModels; //first, update listModels this.http.put(this.coreUrl + 'rest/listModels/itemId/' + user.user_id + '/itemMode/dest/objectType/entity_id', user) .subscribe(function (data) { if (data.errors) { - errorNotification(data.errors); + _this.notify.error(data.errors); } else { //then delete user - _this.http.delete(_this.coreUrl + 'rest/users/' + user.user_id) + _this.http.delete(_this.coreUrl + 'rest/users/' + user.id) .subscribe(function (data) { user.inDiffListDest = 'N'; + _this.data = data.users; $j('#changeDiffListDest').modal('hide'); - for (var i = 0; i < _this.users.length; i++) { - if (_this.users[i].user_id == user.user_id) { - _this.users.splice(i, 1); - } - } - _this.table.row($j("#" + user.user_id)).remove().draw(); - successNotification(data.success); + _this.notify.success(_this.lang.userDeleted + ' « ' + user.user_id + ' »'); }, function (err) { - errorNotification(JSON.parse(err._body).errors); + _this.notify.error(JSON.parse(err._body).errors); }); } }, function (err) { - errorNotification(JSON.parse(err._body).errors); + _this.notify.error(JSON.parse(err._body).errors); }); } }; @@ -233,8 +195,9 @@ var UsersAdministrationComponent = (function () { UsersAdministrationComponent = __decorate([ core_1.Component({ templateUrl: angularGlobals["users-administrationView"], - styleUrls: ['css/users-administration.component.css', '../../node_modules/bootstrap/dist/css/bootstrap.min.css'] + styleUrls: ['css/users-administration.component.css'], + providers: [notification_service_1.NotificationService] }), - __metadata("design:paramtypes", [http_1.HttpClient]) + __metadata("design:paramtypes", [http_1.HttpClient, notification_service_1.NotificationService]) ], UsersAdministrationComponent); exports.UsersAdministrationComponent = UsersAdministrationComponent; diff --git a/apps/maarch_entreprise/js/angular/app/administration/users-administration.component.ts b/apps/maarch_entreprise/js/angular/app/administration/users-administration.component.ts index 13273514a6d8c580f8986e5da8e6d13bbfa24bb0..cc4aa276fbd690202622a9b74739c4afcf431271 100755 --- a/apps/maarch_entreprise/js/angular/app/administration/users-administration.component.ts +++ b/apps/maarch_entreprise/js/angular/app/administration/users-administration.component.ts @@ -1,38 +1,51 @@ -import { Component, OnInit } from '@angular/core'; +import { Component, OnInit, Pipe, PipeTransform} from '@angular/core'; import { HttpClient } from '@angular/common/http'; +import { LANG } from '../translate.component'; +import { NotificationService } from '../notification.service'; declare function $j(selector: any) : any; -declare function successNotification(message: string) : void; -declare function errorNotification(message: string) : void; declare var angularGlobals : any; +@Pipe({ name: 'dataPipe' }) +export class DataTablePipe implements PipeTransform { + transform(array: any[], field: string, query: string): any { + if (query) { + query = query.toLowerCase(); + console.log(array); + return array.filter((value: any) => + value[field].toLowerCase().indexOf(query) > -1); + } + return array; + } +} @Component({ templateUrl : angularGlobals["users-administrationView"], - styleUrls : ['css/users-administration.component.css','../../node_modules/bootstrap/dist/css/bootstrap.min.css'] + styleUrls : ['css/users-administration.component.css'], + providers : [NotificationService] }) -export class UsersAdministrationComponent implements OnInit { +export class UsersAdministrationComponent implements OnInit { + search : string = null; + coreUrl : string; users : any[] = []; userDestRedirect : any = {}; userDestRedirectModels : any[] = []; - lang : any = {}; - table : any; + lang : any = LANG; - resultInfo : string = ""; loading : boolean = false; - - constructor(public http: HttpClient) { + data : any = []; + constructor(public http: HttpClient, private notify: NotificationService) { } updateBreadcrumb(applicationName: string) { if ($j('#ariane')[0]) { - $j('#ariane')[0].innerHTML = "<a href='index.php?reinit=true'>" + applicationName + "</a> > <a onclick='location.hash = \"/administration\"' style='cursor: pointer'>Administration</a> > Utilisateurs"; + $j('#ariane')[0].innerHTML = "<a href='index.php?reinit=true'>" + applicationName + "</a> > <a onclick='location.hash = \"/administration\"' style='cursor: pointer'>"+this.lang.administration+"</a> > "+this.lang.users; } } @@ -45,40 +58,11 @@ export class UsersAdministrationComponent implements OnInit { this.http.get(this.coreUrl + 'rest/administration/users') .subscribe((data : any) => { this.users = data['users']; - this.lang = data.lang; - + this.data = this.users; + this.loading = false; setTimeout(() => { - this.table = $j('#usersTable').DataTable({ - "dom": '<"datatablesLeft"p><"datatablesRight"f><"datatablesCenter"l>rt<"datatablesCenter"i><"clear">', - "lengthMenu": [ 10, 25, 50, 75, 100 ], - "oLanguage": { - "sLengthMenu": "<i class='fa fa-bars'></i> _MENU_", - "sZeroRecords": this.lang.noResult, - "sInfo": "_START_ - _END_ / _TOTAL_ "+this.lang.record, - "sSearch": "", - "oPaginate": { - "sFirst": "<<", - "sLast": ">>", - "sNext": this.lang.next+" <i class='fa fa-caret-right'></i>", - "sPrevious": "<i class='fa fa-caret-left'></i> "+this.lang.previous - }, - "sInfoEmpty": this.lang.noRecord, - "sInfoFiltered": "(filtré de _MAX_ "+this.lang.record+")" - }, - "order": [[ 1, "asc" ]], - "columnDefs": [ - { "orderable": false, "targets": [3,5] } - ] - }); - $j('.dataTables_filter input').attr("placeholder", this.lang.search); - $j('dataTables_filter input').addClass('form-control'); - $j(".datatablesLeft").css({"float":"left"}); - $j(".datatablesCenter").css({"text-align":"center"}); - $j(".datatablesRight").css({"float":"right"}); - + $j("[md2sortby='user_id']").click(); }, 0); - - this.loading = false; }, () => { location.href = "index.php"; }); @@ -91,42 +75,29 @@ export class UsersAdministrationComponent implements OnInit { this.http.get(this.coreUrl + 'rest/listModels/itemId/'+user.user_id+'/itemMode/dest/objectType/entity_id') .subscribe((data : any) => { this.userDestRedirectModels = data.listModels; - setTimeout(() => { - $j(".redirectDest").typeahead({ - order: "asc", - display: "formattedUser", - templateValue: "{{user_id}}", - source: { - ajax: { - type: "GET", - dataType: "json", - url: this.coreUrl + "rest/users/autocompleter/exclude/"+user.user_id, - } - } - }); - }, 0); }, (err) => { console.log(err); location.href = "index.php"; }); } else { - let r = confirm(this.lang.suspendMsg + " ?"); + let r = confirm(this.lang.confirmAction+' '+this.lang.suspend+' « '+user.user_id+' »'); if (r) { user.enabled = 'N'; this.http.put(this.coreUrl + 'rest/users/' + user.id, user) .subscribe((data : any) => { - successNotification(data.success); + this.notify.success(this.lang.userSuspended+' « '+user.user_id+' »'); + }, (err) => { user.enabled = 'Y'; - errorNotification(JSON.parse(err._body).errors); + this.notify.error(JSON.parse(err._body).errors); }); } } } suspendUserModal(user: any) { - let r = confirm(this.lang.suspendMsg + " ?"); + let r = confirm(this.lang.confirmAction+' '+this.lang.suspend+' « '+user.user_id+' »'); if (r) { user.enabled = 'N'; @@ -136,42 +107,45 @@ export class UsersAdministrationComponent implements OnInit { .subscribe((data : any) => { if (data.errors) { user.enabled = 'Y'; - errorNotification(data.errors); + this.notify.error(data.errors); } else { //then suspend user - this.http.put(this.coreUrl + 'rest/users/' + user.user_id, user) + this.http.put(this.coreUrl + 'rest/users/' + user.id, user) .subscribe((data : any) => { user.inDiffListDest = 'N'; $j('#changeDiffListDest').modal('hide'); - successNotification(data.success); + this.notify.success(this.lang.userSuspended+' « '+user.user_id+' »'); + }, (err) => { user.enabled = 'Y'; - errorNotification(JSON.parse(err._body).errors); + this.notify.error(JSON.parse(err._body).errors); }); } }, (err) => { - errorNotification(JSON.parse(err._body).errors); + this.notify.error(JSON.parse(err._body).errors); }); } } activateUser(user: any) { - let r = confirm(this.lang.authorizeMsg + " ?"); + let r = confirm(this.lang.confirmAction+' '+this.lang.authorize+' « '+user.user_id+' »'); if (r) { user.enabled = 'Y'; this.http.put(this.coreUrl + 'rest/users/' + user.id, user) .subscribe((data : any) => { - successNotification(data.success); + this.notify.success(this.lang.userAuthorized+' « '+user.user_id+' »'); + }, (err) => { user.enabled = 'N'; - errorNotification(JSON.parse(err._body).errors); + this.notify.error(JSON.parse(err._body).errors); }); } } deleteUser(user: any) { + if(user.inDiffListDest == 'Y') { user.mode = 'del'; this.userDestRedirect = user; @@ -179,44 +153,27 @@ export class UsersAdministrationComponent implements OnInit { .subscribe((data : any) => { this.userDestRedirectModels = data.listModels; - setTimeout(() => { - $j(".redirectDest").typeahead({ - order: "asc", - source: { - ajax: { - type: "GET", - dataType: "json", - url: this.coreUrl + "rest/users/autocompleter/exclude/"+user.user_id, - } - } - }); - }); - }, (err) => { - errorNotification(JSON.parse(err._body).errors); + this.notify.error(JSON.parse(err._body).errors); }); - } else { - let r = confirm(this.lang.deleteMsg + " ?"); + } else { + let r = confirm(this.lang.confirmAction+' '+this.lang.delete+' « '+user.user_id+' »'); if (r) { - this.http.delete(this.coreUrl + 'rest/users/' + user.user_id, user) + this.http.delete(this.coreUrl + 'rest/users/' + user.id, user) .subscribe((data : any) => { - for (var i = 0;i<this.users.length;i++) { - if(this.users[i].user_id == user.user_id){ - this.users.splice(i,1); - } - } - this.table.row($j("#"+user.user_id)).remove().draw(); - successNotification(data.success); + this.data = data.users; + this.notify.success(this.lang.userDeleted+' « '+user.user_id+' »'); + }, (err) => { - errorNotification(JSON.parse(err._body).errors); + this.notify.error(JSON.parse(err._body).errors); }); } } } deleteUserModal(user: any) { - let r = confirm(this.lang.deleteMsg + " ?"); + let r = confirm(this.lang.confirmAction+' '+this.lang.delete+' « '+user.user_id+' »'); if (r) { user.redirectListModels = this.userDestRedirectModels; @@ -224,26 +181,22 @@ export class UsersAdministrationComponent implements OnInit { this.http.put(this.coreUrl + 'rest/listModels/itemId/'+user.user_id+'/itemMode/dest/objectType/entity_id', user) .subscribe((data : any) => { if (data.errors) { - errorNotification(data.errors); + this.notify.error(data.errors); } else { //then delete user - this.http.delete(this.coreUrl + 'rest/users/' + user.user_id) + this.http.delete(this.coreUrl + 'rest/users/' + user.id) .subscribe((data : any) => { user.inDiffListDest = 'N'; + this.data = data.users; $j('#changeDiffListDest').modal('hide'); - for (var i = 0;i<this.users.length;i++) { - if(this.users[i].user_id == user.user_id){ - this.users.splice(i,1); - } - } - this.table.row($j("#"+user.user_id)).remove().draw(); - successNotification(data.success); + this.notify.success(this.lang.userDeleted+' « '+user.user_id+' »'); + }, (err) => { - errorNotification(JSON.parse(err._body).errors); + this.notify.error(JSON.parse(err._body).errors); }); } }, (err) => { - errorNotification(JSON.parse(err._body).errors); + this.notify.error(JSON.parse(err._body).errors); }); } } diff --git a/apps/maarch_entreprise/js/angular/app/app-material.module.js b/apps/maarch_entreprise/js/angular/app/app-material.module.js index e572d379a363743ce45d71ef4d443f85bd357bf7..a8dab892802ed36558af1236247f70bccf4f93ca 100644 --- a/apps/maarch_entreprise/js/angular/app/app-material.module.js +++ b/apps/maarch_entreprise/js/angular/app/app-material.module.js @@ -18,12 +18,34 @@ AppMaterialModule = __decorate([ imports: [ material_1.MdCheckboxModule, material_1.MdSelectModule, - material_1.MdRadioModule + material_1.MdSlideToggleModule, + material_1.MdInputModule, + material_1.MdTooltipModule, + material_1.MdTabsModule, + material_1.MdSidenavModule, + material_1.MdButtonModule, + material_1.MdCardModule, + material_1.MdButtonToggleModule, + material_1.MdProgressSpinnerModule, + material_1.MdToolbarModule, + material_1.MdMenuModule, + material_1.MdGridListModule ], exports: [ material_1.MdCheckboxModule, material_1.MdSelectModule, - material_1.MdRadioModule + material_1.MdSlideToggleModule, + material_1.MdInputModule, + material_1.MdTooltipModule, + material_1.MdTabsModule, + material_1.MdSidenavModule, + material_1.MdButtonModule, + material_1.MdCardModule, + material_1.MdButtonToggleModule, + material_1.MdProgressSpinnerModule, + material_1.MdToolbarModule, + material_1.MdMenuModule, + material_1.MdGridListModule ] }) ], AppMaterialModule); diff --git a/apps/maarch_entreprise/js/angular/app/app-material.module.ts b/apps/maarch_entreprise/js/angular/app/app-material.module.ts index c266a44e9c9d25d4b46488a3781c53ba9d9fcd8d..142acaf37fe12f01305303df96fec532f59c5c6d 100644 --- a/apps/maarch_entreprise/js/angular/app/app-material.module.ts +++ b/apps/maarch_entreprise/js/angular/app/app-material.module.ts @@ -2,7 +2,18 @@ import { NgModule } from '@angular/core'; import { MdSelectModule, MdCheckboxModule, - MdRadioModule + MdSlideToggleModule, + MdInputModule, + MdTooltipModule, + MdTabsModule, + MdSidenavModule, + MdButtonModule, + MdCardModule, + MdButtonToggleModule, + MdProgressSpinnerModule, + MdToolbarModule, + MdMenuModule, + MdGridListModule } from '@angular/material'; @@ -10,12 +21,34 @@ import { imports: [ MdCheckboxModule, MdSelectModule, - MdRadioModule + MdSlideToggleModule, + MdInputModule, + MdTooltipModule, + MdTabsModule, + MdSidenavModule, + MdButtonModule, + MdCardModule, + MdButtonToggleModule, + MdProgressSpinnerModule, + MdToolbarModule, + MdMenuModule, + MdGridListModule ], exports: [ MdCheckboxModule, MdSelectModule, - MdRadioModule + MdSlideToggleModule, + MdInputModule, + MdTooltipModule, + MdTabsModule, + MdSidenavModule, + MdButtonModule, + MdCardModule, + MdButtonToggleModule, + MdProgressSpinnerModule, + MdToolbarModule, + MdMenuModule, + MdGridListModule ] }) export class AppMaterialModule { } diff --git a/apps/maarch_entreprise/js/angular/app/app.component.js b/apps/maarch_entreprise/js/angular/app/app.component.js index 33439b8c6e5cd8835b2de00882d6e67927448050..7040e6a6ddf632855b57dbfc6c924203d981e108 100755 --- a/apps/maarch_entreprise/js/angular/app/app.component.js +++ b/apps/maarch_entreprise/js/angular/app/app.component.js @@ -15,8 +15,15 @@ var AppComponent = (function () { AppComponent = __decorate([ core_1.Component({ selector: 'my-app', - template: "<div id=\"resultInfo\" class=\"fade\" style=\"display:none;\"></div><router-outlet></router-outlet>", - styleUrls: ['../../node_modules/bootstrap/dist/css/bootstrap.min.css'] + //template: `<menu-app></menu-app><router-outlet></router-outlet>`, + template: "<router-outlet></router-outlet>", + encapsulation: core_1.ViewEncapsulation.None, + styleUrls: [ + '../../node_modules/bootstrap/dist/css/bootstrap.min.css', + '../../node_modules/@angular/material/prebuilt-themes/indigo-pink.css', + 'css/engine.css', + 'css/jstree-custom.min.css' //treejs module + ] }) ], AppComponent); exports.AppComponent = AppComponent; diff --git a/apps/maarch_entreprise/js/angular/app/app.component.ts b/apps/maarch_entreprise/js/angular/app/app.component.ts index ee44d3143842c56385dcc443211f9cafb1e284dd..841d450dd0b3b0dedd13f672bca781d2bc9fb804 100755 --- a/apps/maarch_entreprise/js/angular/app/app.component.ts +++ b/apps/maarch_entreprise/js/angular/app/app.component.ts @@ -1,8 +1,15 @@ -import { Component } from '@angular/core'; +import { Component, ViewEncapsulation } from '@angular/core'; @Component({ - selector: 'my-app', - template: `<div id="resultInfo" class="fade" style="display:none;"></div><router-outlet></router-outlet>`, - styleUrls : ['../../node_modules/bootstrap/dist/css/bootstrap.min.css'] + selector: 'my-app', + //template: `<menu-app></menu-app><router-outlet></router-outlet>`, + template: `<router-outlet></router-outlet>`, + encapsulation: ViewEncapsulation.None, + styleUrls : [ + '../../node_modules/bootstrap/dist/css/bootstrap.min.css', + '../../node_modules/@angular/material/prebuilt-themes/indigo-pink.css', + 'css/engine.css', + 'css/jstree-custom.min.css' //treejs module + ] }) export class AppComponent {} diff --git a/apps/maarch_entreprise/js/angular/app/app.module.js b/apps/maarch_entreprise/js/angular/app/app.module.js index 748f117ab91b2cdbed94516c2d3616ff726d54bb..8bcaa65780b5345b8c9bf97c2a280bdd07890476 100755 --- a/apps/maarch_entreprise/js/angular/app/app.module.js +++ b/apps/maarch_entreprise/js/angular/app/app.module.js @@ -11,6 +11,9 @@ var platform_browser_1 = require("@angular/platform-browser"); var animations_1 = require("@angular/platform-browser/animations"); var forms_1 = require("@angular/forms"); var http_1 = require("@angular/common/http"); +var app_material_module_1 = require("./app-material.module"); +var md2_1 = require("md2"); +var header_component_1 = require("./header.component"); var app_component_1 = require("./app.component"); var app_routing_module_1 = require("./app-routing.module"); var administration_module_1 = require("./administration/administration.module"); @@ -29,9 +32,12 @@ AppModule = __decorate([ forms_1.FormsModule, http_1.HttpClientModule, administration_module_1.AdministrationModule, - app_routing_module_1.AppRoutingModule + app_routing_module_1.AppRoutingModule, + app_material_module_1.AppMaterialModule, + md2_1.Md2Module ], declarations: [ + header_component_1.HeaderComponent, app_component_1.AppComponent, profile_component_1.ProfileComponent, signature_book_component_1.SignatureBookComponent, diff --git a/apps/maarch_entreprise/js/angular/app/app.module.ts b/apps/maarch_entreprise/js/angular/app/app.module.ts index c3afb563acfe5819d4eff1228230cfdc7a5e269d..a21c8654434e4747cfe6051e35f6b9924146ffa7 100755 --- a/apps/maarch_entreprise/js/angular/app/app.module.ts +++ b/apps/maarch_entreprise/js/angular/app/app.module.ts @@ -3,7 +3,10 @@ import { BrowserModule } from '@angular/platform-browser' import { BrowserAnimationsModule } from '@angular/platform-browser/animations'; import { FormsModule } from '@angular/forms'; import { HttpClientModule } from '@angular/common/http'; +import { AppMaterialModule } from './app-material.module'; +import { Md2Module } from 'md2'; +import { HeaderComponent } from './header.component'; import { AppComponent } from './app.component'; import { AppRoutingModule } from './app-routing.module'; import { AdministrationModule } from './administration/administration.module'; @@ -12,20 +15,23 @@ import { ProfileComponent } from './profile.component'; import { SignatureBookComponent, SafeUrlPipe } from './signature-book.component'; @NgModule({ - imports: [ - BrowserModule, - BrowserAnimationsModule, - FormsModule, - HttpClientModule, - AdministrationModule, - AppRoutingModule - ], - declarations: [ - AppComponent, - ProfileComponent, - SignatureBookComponent, - SafeUrlPipe - ], - bootstrap: [ AppComponent] + imports: [ + BrowserModule, + BrowserAnimationsModule, + FormsModule, + HttpClientModule, + AdministrationModule, + AppRoutingModule, + AppMaterialModule, + Md2Module + ], + declarations: [ + HeaderComponent, + AppComponent, + ProfileComponent, + SignatureBookComponent, + SafeUrlPipe + ], + bootstrap: [AppComponent] }) export class AppModule { } diff --git a/apps/maarch_entreprise/js/angular/app/header.component.js b/apps/maarch_entreprise/js/angular/app/header.component.js index 37e2700ffd6f26d906ffe49704ae5bc00d111a30..de807b59a8a2d1849538bde555b20f180d73478b 100755 --- a/apps/maarch_entreprise/js/angular/app/header.component.js +++ b/apps/maarch_entreprise/js/angular/app/header.component.js @@ -14,17 +14,38 @@ var http_1 = require("@angular/common/http"); var HeaderComponent = (function () { function HeaderComponent(http) { this.http = http; - this.lang = {}; - this.resultInfo = ""; - this.loading = false; + this.applicationName = ""; + this.adminList = []; + this.adminListModule = []; + this.menuList = []; + this.profilList = []; + this.notifList = []; } HeaderComponent.prototype.prepareHeader = function () { - $j('#header').remove(); + $j('#maarch_content').remove(); }; HeaderComponent.prototype.ngOnInit = function () { + var _this = this; this.prepareHeader(); this.coreUrl = angularGlobals.coreUrl; - this.loading = true; + this.http.get(this.coreUrl + 'rest/administration') + .subscribe(function (data) { + _this.menuList = data.menu.menuList; + _this.applicationName = data.menu.applicationName[0]; + _this.adminList = data.application; + _this.adminListModule = data.modules; + }); + this.profilList = [ + { + label: 'Mon profil', + link: '/profile', + style: 'fa-user' + }, + { label: 'Déconnexion', + link: '/logout', + style: 'fa-sign-out' + } + ]; }; return HeaderComponent; }()); @@ -34,7 +55,6 @@ HeaderComponent = __decorate([ templateUrl: angularGlobals["headerView"], styleUrls: [ 'css/header.component.css', - '../../node_modules/bootstrap/dist/css/bootstrap.min.css' //load bootstrap css ] }), __metadata("design:paramtypes", [http_1.HttpClient]) diff --git a/apps/maarch_entreprise/js/angular/app/header.component.ts b/apps/maarch_entreprise/js/angular/app/header.component.ts index 711c272d854133253415d1e753d385e5e53383b8..e3015adc8876461f6373608d437f51597f701538 100755 --- a/apps/maarch_entreprise/js/angular/app/header.component.ts +++ b/apps/maarch_entreprise/js/angular/app/header.component.ts @@ -10,26 +10,26 @@ declare var angularGlobals : any; selector: 'menu-app', templateUrl : angularGlobals["headerView"], styleUrls : [ - 'css/header.component.css', //load specific custom css - '../../node_modules/bootstrap/dist/css/bootstrap.min.css' //load bootstrap css - ] + 'css/header.component.css', //load specific custom css + ] }) export class HeaderComponent implements OnInit { coreUrl : string; - lang : any = {}; - table : any; - - resultInfo : string = ""; - loading : boolean = false; + applicationName : string = ""; + adminList : any[] = []; + adminListModule : any[] = []; + menuList : any[] = []; + profilList : any[] = []; + notifList : any[] = []; constructor(public http: HttpClient) { } prepareHeader() { - $j('#header').remove(); + $j('#maarch_content').remove(); } ngOnInit(): void { @@ -37,7 +37,24 @@ export class HeaderComponent implements OnInit { this.coreUrl = angularGlobals.coreUrl; - this.loading = true; - + this.http.get(this.coreUrl + 'rest/administration') + .subscribe((data : any) => { + this.menuList = data.menu.menuList; + this.applicationName = data.menu.applicationName[0]; + this.adminList = data.application; + this.adminListModule = data.modules; + }); + + this.profilList = [ + { + label : 'Mon profil', + link : '/profile', + style : 'fa-user' + }, + { label : 'Déconnexion', + link : '/logout', + style : 'fa-sign-out' + } + ] } } diff --git a/apps/maarch_entreprise/js/angular/app/notification.service.js b/apps/maarch_entreprise/js/angular/app/notification.service.js new file mode 100644 index 0000000000000000000000000000000000000000..60748d8cf7fbab977286ecd2c6353751ffdd032b --- /dev/null +++ b/apps/maarch_entreprise/js/angular/app/notification.service.js @@ -0,0 +1,30 @@ +"use strict"; +var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +}; +var __metadata = (this && this.__metadata) || function (k, v) { + if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); +}; +Object.defineProperty(exports, "__esModule", { value: true }); +var md2_1 = require("md2"); +var core_1 = require("@angular/core"); +var NotificationService = (function () { + function NotificationService(toast) { + this.toast = toast; + } + NotificationService.prototype.success = function (message) { + this.toast.show('<i class="fa fa-info-circle fa-2x"></i><span>' + message + '</span>', 2000); + }; + NotificationService.prototype.error = function (message) { + this.toast.show('<i class="fa fa-exclamation-triangle fa-2x"></i><span>' + message + '</span>', 2000); + }; + return NotificationService; +}()); +NotificationService = __decorate([ + core_1.Injectable(), + __metadata("design:paramtypes", [md2_1.Md2Toast]) +], NotificationService); +exports.NotificationService = NotificationService; diff --git a/apps/maarch_entreprise/js/angular/app/notification.service.ts b/apps/maarch_entreprise/js/angular/app/notification.service.ts new file mode 100644 index 0000000000000000000000000000000000000000..7eb2de712d4c3fef1e514ee530170aa355dddcb6 --- /dev/null +++ b/apps/maarch_entreprise/js/angular/app/notification.service.ts @@ -0,0 +1,15 @@ +import {Md2Toast} from 'md2'; +import {Injectable} from '@angular/core'; + +@Injectable() +export class NotificationService { + constructor(private toast: Md2Toast) { + } + success(message:string) { + this.toast.show('<i class="fa fa-info-circle fa-2x"></i><span>'+message+'</span>', 2000); + } + + error(message:string) { + this.toast.show('<i class="fa fa-exclamation-triangle fa-2x"></i><span>'+message+'</span>', 2000); + } +} \ No newline at end of file diff --git a/apps/maarch_entreprise/js/angular/lang/lang-fr.js b/apps/maarch_entreprise/js/angular/lang/lang-fr.js index 5beb77ca4c33793e19eeb70b46cc87a8a26930d7..4c173e0e2bcd1793f4542026d3100437f3057613 100755 --- a/apps/maarch_entreprise/js/angular/lang/lang-fr.js +++ b/apps/maarch_entreprise/js/angular/lang/lang-fr.js @@ -28,26 +28,13 @@ exports.LANG_FR = { "deleteMsg": "Voulez-vous vraiment supprimer cet élément", "clickOn": "Cliquez sur", "to": "vers", - "user": "utilisateur", - "informations": "Informations", - "firstname": "Prénom", - "lastname": "Nom", - "email": "Email", - "phoneNumber": "Numéro de téléphone", - "role": "Rôle", - "emailSignatures": "Signatures de mail", - "sbSignatures": "Signatures de parapheur", - "initials": "Initiales", - "fingerprint": "Empreinte numérique", - "color": "Couleur", - "label": "Label", - "processDelay": "Délai de traitement", - "workingDays": "Jours travaillés", - "folders": "Dossiers", - "groups": "Groupes", - "entities": "Entités", - "primaryEntity": "Entité Primaire", - "secondaryEntity": "Entité Secondaire", + "value": "valeur", + confirmAction: "Voulez-vous vraiment effectuer cette action ?", + suspend: "Suspendre", + authorize: "Autoriser", + for: "pour", + noSelection: "aucune sélection", + table: "Table", //Administration "userCreation": "Création d'un utilisateur", "userModification": "Modification de l'utilisateur", @@ -62,11 +49,10 @@ exports.LANG_FR = { "newSignature": "Nouvelle signature", "manageAbsences": "Gérer les absences", "activateAbsence": "Activer l'absence", - "deactivateAbsence": "Désactiver l'absence", + "desactivateAbsence": "Désactiver l'absence", "autoLogoutAbsence": "Vous allez être automatiquement déconnecté après avoir défini vos redirections de bannettes", "reports": "Etats et éditions", "myProfile": "Mon profil", - "event": "Evènement", "template": "Modèle", "diffusion_type": "Type de diffusion", //Notifications @@ -89,14 +75,64 @@ exports.LANG_FR = { records: "résultats", recordsPerPage: "résultats par page", search: "Chercher", + filterBy: "Filtrer par", + //Users + absOff: "Absence désactivé", + absOn: "Absence activé", + activateAbs: "Activer l'absence", + color: "Couleur", + email: "Email", + emailSignatures: "Signatures de mail", + entities: "Entités", + fingerprint: "Empreinte numérique", + firstname: "Prénom", + folders: "Dossiers", + groups: "Groupes", + informations: "Informations", + initials: "Initiales", + label: "Label", + lastname: "Nom", + phoneNumber: "Numéro de téléphone", + primaryEntity: "Entité Primaire", + processDelay: "Délai de traitement", + pswReseted: "Mot de passe réinitialisé", + resetPsw: "Réinitialiser le mot de passe", + role: "Rôle", + sbSignatures: "Signatures de parapheur", + secondaryEntity: "Entité Secondaire", + signAdded: "Signature ajoutée", + signDeleted: "Signature supprimée", + signUpdated: "Signature modifiée", + status: "Statut", + user: "Utilisateur", + userAdded: "Utilisateur ajouté", + userAuthorized: "Utilisateur autorisé", + userDeleted: "Utilisateur supprimé", + users: "Utilisateur(s)", + userSuspended: "Utilisateur suspendu", + userUpdated: "Utilisateur modifié", + workingDays: "Jours travaillés", + //Group + groupAdded: "Groupe ajouté", + groupDeleted: "Groupe supprimé", + groupUpdated: "Groupe modifié", + //Entity + entityAdded: "Entité ajouté", + entityDeleted: "Entité supprimé", + entityTooglePrimary: "Passage en entité primaire", + entityUpdated: "Entité modifié", //Actions action: "Action", - actionAdded: "Ajout d'une nouvelle action", + actionAdded: "Action ajoutée", + actionCreation: "Création d'une action", + actionDeleted: "Action supprimée", actionHistory: "Tracer l'action", actionHistoryDesc: "Permet tracer cette action dans l'historique du document. Il est fortement recommandé de cocher cette option.", + actionModification: "Modification de l'action", actionModified: "Modification de l'action", actionPage: "Page de résultat de l'action", actions: "Action(s)", + actionUpdated: "Action modifiée", associatedStatus: "Statut associé", chooseCategoryAssociation: "Choisissez une ou plusieurs catégories associée", chooseCategoryAssociationHelp: "Si aucune catégorie sélectionnée alors l'action est valable pour toute les catégories", @@ -104,18 +140,40 @@ exports.LANG_FR = { infosActions: "Vous devez choisir au moins un statut et / ou un script.", isFolderAction: "Action de dossier", isFolderActionDesc: "Permet d'utiliser cette action dans une bannette de dossier", + isSytemAction: "Action système", keyword: "Mot clé", newAction: "Nouvelle action", - sendToDestFromGroups: "Envoi aux utilisateurs du(des) groupe(s) spécifié(s):", - sendToDestFromentities: "Envoi aux utilisateurs des entité(s) spécifié(s):", - sendToMainDestUserWithStatus: "Envoi au destinataire principal du document avec le(s) statut(s):", - sendToUsers: "Envoi aux utilisateurs spécifiés:", - sendToCopyUsers: "Envoi aux utilisateurs en copie du document", - sendToMainDestUser: "Envoi au destinataire principal du document", - sendToContact: "Envoi à l'expéditeur du courrier", - sendToVisaUserWithStatus: "Envoi à l'utilisateur devant viser avec le(s) statut(s):", - sendToSignUserWithStatus: "Envoi à l'utilisateur devant signer avec le(s) statut(s):", - authorization: "Autorisé :", - joinDoc: "Joindre le document à la notification :", - newNotificationAdded: "Nouvelle notification créée ", + //Parameter + date: "Date", + integer: "Entier", + parameterAdded: "Paramètre ajouté", + parameterCreation: "Création d'un paramètre", + parameterDeleted: "Paramètre supprimé", + parameterModification: "Modification du paramètre", + parameters: "Paramètre(s)", + parameterUpdated: "Paramètre modifié", + string: "Chaine de caratère", + type: "Type", + //Status + canBeModified: "Modification des index", + canBeSearched: "Recherche", + imgRelated: "Image associée", + isFolderStatus: "Statut de dossier", + statusAdded: "Statut ajouté", + statusCreation: "Création d'un statut", + statusDeleted: "Statut supprimé", + statuses: "Statut(s)", + statusModification: "Modification du statut", + statusUpdated: "Statut mis à jour", + //History + dataOfMonth: "Données du mois", + entries: "entrée(s)", + event: "Événement", + history: "Historique", + ip: "Adresse IP", + //HistoryBatch + historyBatch: "Historique des batchs", + totalProcessed: "Élément(s) analysé(s)", + totalErrors: "Élément(s) en erreur", + module: "Module" }; diff --git a/apps/maarch_entreprise/js/angular/lang/lang-fr.ts b/apps/maarch_entreprise/js/angular/lang/lang-fr.ts index dc0c1817a817d9a93a97e18df59e530b04d5573b..1890df43d916579b867a7efb3445a0772cc7eee3 100755 --- a/apps/maarch_entreprise/js/angular/lang/lang-fr.ts +++ b/apps/maarch_entreprise/js/angular/lang/lang-fr.ts @@ -26,27 +26,14 @@ export const LANG_FR = { "deleteMsg" : "Voulez-vous vraiment supprimer cet élément", "clickOn" : "Cliquez sur", "to" : "vers", - "user" : "utilisateur", - "informations" : "Informations", - "firstname" : "Prénom", - "lastname" : "Nom", - "email" : "Email", - "phoneNumber" : "Numéro de téléphone", - "role" : "Rôle", - "emailSignatures" : "Signatures de mail", - "sbSignatures" : "Signatures de parapheur", - "initials" : "Initiales", - "fingerprint" : "Empreinte numérique", - "color" : "Couleur", - "label" : "Label", - "processDelay" : "Délai de traitement", - "workingDays" : "Jours travaillés", - "folders" : "Dossiers", - "groups" : "Groupes", - "entities" : "Entités", - "primaryEntity" : "Entité Primaire", - "secondaryEntity" : "Entité Secondaire", - + "value" : "valeur", + confirmAction: "Voulez-vous vraiment effectuer cette action ?", + suspend: "Suspendre", + authorize: "Autoriser", + for: "pour", + noSelection: "aucune sélection", + table: "Table", + //Administration "userCreation" : "Création d'un utilisateur", @@ -62,7 +49,7 @@ export const LANG_FR = { "newSignature" : "Nouvelle signature", "manageAbsences" : "Gérer les absences", "activateAbsence" : "Activer l'absence", - "deactivateAbsence" : "Désactiver l'absence", + "desactivateAbsence" : "Désactiver l'absence", "autoLogoutAbsence" : "Vous allez être automatiquement déconnecté après avoir défini vos redirections de bannettes", "reports" : "Etats et éditions", "myProfile" : "Mon profil", @@ -93,16 +80,69 @@ export const LANG_FR = { records: "résultats", recordsPerPage: "résultats par page", search: "Chercher", + filterBy: "Filtrer par", + //Users + absOff: "Absence désactivé", + absOn: "Absence activé", + activateAbs: "Activer l'absence", + color: "Couleur", + email: "Email", + emailSignatures: "Signatures de mail", + entities: "Entités", + fingerprint: "Empreinte numérique", + firstname: "Prénom", + folders: "Dossiers", + groups: "Groupes", + informations: "Informations", + initials: "Initiales", + label: "Label", + lastname: "Nom", + phoneNumber: "Numéro de téléphone", + primaryEntity: "Entité Primaire", + processDelay: "Délai de traitement", + pswReseted: "Mot de passe réinitialisé", + resetPsw: "Réinitialiser le mot de passe", + role: "Rôle", + sbSignatures: "Signatures de parapheur", + secondaryEntity: "Entité Secondaire", + signAdded: "Signature ajoutée", + signDeleted: "Signature supprimée", + signUpdated: "Signature modifiée", + status: "Statut", + user: "Utilisateur", + userAdded: "Utilisateur ajouté", + userAuthorized: "Utilisateur autorisé", + userDeleted: "Utilisateur supprimé", + users: "Utilisateur(s)", + userSuspended: "Utilisateur suspendu", + userUpdated: "Utilisateur modifié", + workingDays: "Jours travaillés", + + + //Group + groupAdded: "Groupe ajouté", + groupDeleted: "Groupe supprimé", + groupUpdated: "Groupe modifié", + //Entity + entityAdded: "Entité ajouté", + entityDeleted: "Entité supprimé", + entityTooglePrimary: "Passage en entité primaire", + entityUpdated: "Entité modifié", + //Actions action: "Action", - actionAdded: "Ajout d'une nouvelle action", + actionAdded: "Action ajoutée", + actionCreation: "Création d'une action", + actionDeleted: "Action supprimée", actionHistory: "Tracer l'action", actionHistoryDesc: "Permet tracer cette action dans l'historique du document. Il est fortement recommandé de cocher cette option.", + actionModification: "Modification de l'action", actionModified: "Modification de l'action", actionPage: "Page de résultat de l'action", actions: "Action(s)", + actionUpdated: "Action modifiée", associatedStatus: "Statut associé", chooseCategoryAssociation: "Choisissez une ou plusieurs catégories associée", chooseCategoryAssociationHelp: "Si aucune catégorie sélectionnée alors l'action est valable pour toute les catégories", @@ -110,19 +150,46 @@ export const LANG_FR = { infosActions: "Vous devez choisir au moins un statut et / ou un script.", isFolderAction: "Action de dossier", isFolderActionDesc: "Permet d'utiliser cette action dans une bannette de dossier", + isSytemAction: "Action système", keyword: "Mot clé", newAction: "Nouvelle action", - sendToDestFromGroups : "Envoi aux utilisateurs du(des) groupe(s) spécifié(s):", - sendToDestFromentities : "Envoi aux utilisateurs des entité(s) spécifié(s):", - sendToMainDestUserWithStatus : "Envoi au destinataire principal du document avec le(s) statut(s):", - sendToUsers : "Envoi aux utilisateurs spécifiés:", - sendToCopyUsers : "Envoi aux utilisateurs en copie du document", - sendToMainDestUser : "Envoi au destinataire principal du document", - sendToContact : "Envoi à l'expéditeur du courrier", - sendToVisaUserWithStatus : "Envoi à l'utilisateur devant viser avec le(s) statut(s):", - sendToSignUserWithStatus : "Envoi à l'utilisateur devant signer avec le(s) statut(s):", - authorization : "Autorisé :", - joinDoc : "Joindre le document à la notification :", - newNotificationAdded : "Nouvelle notification créée ", + //Parameter + date:"Date", + integer:"Entier", + parameterAdded: "Paramètre ajouté", + parameterCreation: "Création d'un paramètre", + parameterDeleted: "Paramètre supprimé", + parameterModification: "Modification du paramètre", + parameters: "Paramètre(s)", + parameterUpdated: "Paramètre modifié", + string:"Chaine de caratère", + type:"Type", + + //Status + canBeModified: "Modification des index", + canBeSearched: "Recherche", + imgRelated: "Image associée", + isFolderStatus: "Statut de dossier", + statusAdded: "Statut ajouté", + statusCreation: "Création d'un statut", + statusDeleted: "Statut supprimé", + statuses: "Statut(s)", + statusModification: "Modification du statut", + statusUpdated: "Statut mis à jour", + + //History + dataOfMonth: "Données du mois", + entries: "entrée(s)", + event: "Événement", + history: "Historique", + ip: "Adresse IP", + + //HistoryBatch + historyBatch: "Historique des batchs", + totalProcessed: "Élément(s) analysé(s)", + totalErrors: "Élément(s) en erreur", + module: "Module" + + }; \ No newline at end of file diff --git a/apps/maarch_entreprise/js/angular/systemjs.config.js b/apps/maarch_entreprise/js/angular/systemjs.config.js index 8b8ef0c6a13af1561b0a188ebf4ce74eb3bfcaab..dbb88f58f2c36fa1a9b0523e6e4be93b2b2b82c3 100755 --- a/apps/maarch_entreprise/js/angular/systemjs.config.js +++ b/apps/maarch_entreprise/js/angular/systemjs.config.js @@ -28,6 +28,7 @@ '@angular/http': 'npm:@angular/http/bundles/http.umd.min.js', '@angular/material': 'npm:@angular/material/bundles/material.umd.min.js', '@angular/cdk': 'npm:@angular/cdk/bundles/cdk.umd.min.js', + 'md2': 'npm:md2/bundles/md2.umd.js', // other libraries 'rxjs': 'npm:rxjs', diff --git a/apps/maarch_entreprise/js/angularFunctions.js b/apps/maarch_entreprise/js/angularFunctions.js index b3b126341c95dcc2ee960bebbdd7106c9fd35375..f24d6587ed75ef9f05152d914feb433ec9b5b555 100755 --- a/apps/maarch_entreprise/js/angularFunctions.js +++ b/apps/maarch_entreprise/js/angularFunctions.js @@ -9,6 +9,8 @@ function triggerAngular(prodmode, locationToGo) { 'statuses-administration', 'actions-administration', 'action-administration', + 'history-administration', + 'historyBatch-administration', 'profile', 'signature-book', 'parameter-administration', diff --git a/apps/maarch_entreprise/js/functions.js b/apps/maarch_entreprise/js/functions.js index ce9d63084ec876cc73306b6b82db60036d54c701..d78f1ce1f683b7156b1667ef63463b3cc3cb3316 100755 --- a/apps/maarch_entreprise/js/functions.js +++ b/apps/maarch_entreprise/js/functions.js @@ -1793,6 +1793,27 @@ function setContactType(mode, creation){ }); } +function checkContactType(mode,creation){ + var bool = false; + $j.ajax({ + url: 'index.php?dir=my_contacts&page=setContactType&display=false', + type: 'POST', + async: false, + data: { + contact_target: mode, + can_add_contact: creation + }, + success: function(answer){ + if(answer.substring(0,5)=='false'){ + bool =false; + } else{ + bool =true; + } + } + }); + return bool; +} + /** * Show or hide the data related to a person in the contacts admin * @@ -3243,6 +3264,11 @@ function titleWithTooltipster(id){ }); } +function titleWithTooltipsterClass(className){ + $j(document).ready(function() { + $j('.'+className).tooltipster({delay :0}); + }); +} /** Advanced Search **/ /** diff --git a/apps/maarch_entreprise/lang/en.php b/apps/maarch_entreprise/lang/en.php index a89d96073cb0fc2823fb4dbda55e033aa975187c..5c4cf3a99bba0b055c7b7363931673ca2c3a017b 100755 --- a/apps/maarch_entreprise/lang/en.php +++ b/apps/maarch_entreprise/lang/en.php @@ -2043,3 +2043,6 @@ if (!defined("_NEW_ITEM")) define("_NEW_ITEM", "New"); if(!defined('_SAVED_CHANGE')) define('_SAVED_CHANGE', 'Saved change'); /** Generic messages **/ + +if (!defined('_DOC_CREATED_WITH_STATUS')) + define('_DOC_CREATED_WITH_STATUS', 'Document created with status'); \ No newline at end of file diff --git a/apps/maarch_entreprise/lang/fr.php b/apps/maarch_entreprise/lang/fr.php index 7cce282324c84e15bc351f834b637867cc17b599..6af191709f8d0db97076b08fbc77cbbf3577d44b 100755 --- a/apps/maarch_entreprise/lang/fr.php +++ b/apps/maarch_entreprise/lang/fr.php @@ -1136,6 +1136,7 @@ if (!defined("_TO")) define("_TO", "vers"); if (!defined("_FILE_PROPERTIES")) define("_FILE_PROPERTIES", "Propriétés du fichier"); if (!defined("_FILE_DATA")) define("_FILE_DATA", "Informations sur le document"); if (!defined("_VIEW_DOC")) define("_VIEW_DOC", "Voir le document"); +if (!defined("_DOWNLOAD_LOCAL_DOC_COPY")) define("_DOWNLOAD_LOCAL_DOC_COPY", "Télécharger une copie locale"); if (!defined("_VIEW_DOC_DESC")) define("_VIEW_DOC_DESC", "Ouvre une modal avec le document en visualisation. Incrémente également la donnée 'viewed' de la table listinstance (utile si utilisée dans les clauses de bannettes) "); if (!defined("_TYPIST")) define("_TYPIST", "Opérateur"); if (!defined("_LOT")) define("_LOT", "Lot"); @@ -1631,6 +1632,7 @@ if (!defined("_EMAIL_ACCOUNT")) define("_EMAIL_ACCOUNT", "Email compte"); if (!defined("_HELP_KEYWORD_EMAIL")) define("_HELP_KEYWORD_EMAIL", "Email de l'utilisateur connecté"); if (!defined("_INITIATOR")) define("_INITIATOR", "Service initiateur"); +if (!defined("_INITIATORS")) define("_INITIATORS", "Service(s) initiateur(s)"); if (!defined("_QUALIF_BUSINESS")) define("_QUALIF_BUSINESS", "Qualification des documents de la collection business"); if (!defined("_PROCESS_BUSINESS")) define("_PROCESS_BUSINESS", "Traitement des documents de la collection business"); @@ -2090,3 +2092,6 @@ if (!defined('_STATUS_UPDATED')) if(!defined('_SAVED_CHANGE')) define('_SAVED_CHANGE', 'Modification enregistrée'); /** Generic messages **/ + +if (!defined('_DOC_CREATED_WITH_STATUS')) + define('_DOC_CREATED_WITH_STATUS', 'Document créé avec le statut'); diff --git a/apps/maarch_entreprise/merged_css.php b/apps/maarch_entreprise/merged_css.php index cf297a0045b1fda224e357baeb255023bc598ada..571a20760c9c313502c21f27e7bc469b6db9b1c8 100755 --- a/apps/maarch_entreprise/merged_css.php +++ b/apps/maarch_entreprise/merged_css.php @@ -1,5 +1,16 @@ <?php -include_once('../../core/init.php'); +/** +* Copyright Maarch since 2008 under licence GPLv3. +* See LICENCE.txt file at the root folder for more details. +* This file is part of Maarch software. + +* @brief merged_css +* @author dev <dev@maarch.org> +* @ingroup apps +*/ + +require_once '../../core/init.php'; + function compress($buffer) { /* remove comments */ @@ -12,7 +23,7 @@ function compress($buffer) return $buffer; } -$date = mktime(0, 0, 0, date("m") + 2 , date("d"), date("Y")); +$date = mktime(0, 0, 0, date("m") + 2, date("d"), date("Y")); $date = date("D, d M Y H:i:s", $date); $time = 30 * 12 * 60 * 60; header("Pragma: public"); @@ -24,7 +35,8 @@ header('Content-type: text/css; charset=utf-8'); ob_start("compress"); -include 'apps/' . $_SESSION['config']['app_id'] . '/css/styles.css'; +require 'apps/' . $_SESSION['config']['app_id'] . '/css/styles.css'; + foreach (array_keys($_SESSION['modules_loaded']) as $value) { if (file_exists( $_SESSION['config']['corepath'] . 'custom' . DIRECTORY_SEPARATOR @@ -42,24 +54,17 @@ foreach (array_keys($_SESSION['modules_loaded']) as $value) { } } -include_once 'apps/' . $_SESSION['config']['app_id'] . '/css/doctype_levels.css'; -include_once 'apps/' . $_SESSION['config']['app_id'] . '/css/bootstrapTree.css'; +require_once 'apps/' . $_SESSION['config']['app_id'] . '/css/doctype_levels.css'; +require_once 'apps/' . $_SESSION['config']['app_id'] . '/css/bootstrapTree.css'; //Views readfile('apps/maarch_entreprise/css/administration.component.css'); //Dependencies readfile('node_modules/tooltipster/dist/css/tooltipster.bundle.min.css'); -readfile('node_modules/datatables/media/css/jquery.dataTables.min.css'); -readfile('node_modules/jquery-typeahead/dist/jquery.typeahead.min.css'); -readfile('node_modules/@angular/material/prebuilt-themes/indigo-pink.css'); readfile('apps/maarch_entreprise/css/chosen.min.css'); readfile('node_modules/photoswipe/dist/photoswipe.css'); readfile('node_modules/photoswipe/dist/default-skin/default-skin.css'); readfile('apps/maarch_entreprise/css/photoswipe_custom.css'); -//Custom CSS for V2 -readfile('apps/maarch_entreprise/css/engine.css'); -readfile('apps/maarch_entreprise/css/bootstrap-chosen.css'); - ob_end_flush(); diff --git a/apps/maarch_entreprise/merged_js.php b/apps/maarch_entreprise/merged_js.php index 5851615b1a2321045ecb7ba090b664f17c08a66a..5faf5140027a72102560494914a51b2e26c9f9b8 100755 --- a/apps/maarch_entreprise/merged_js.php +++ b/apps/maarch_entreprise/merged_js.php @@ -1,28 +1,19 @@ <?php +/** +* Copyright Maarch since 2008 under licence GPLv3. +* See LICENCE.txt file at the root folder for more details. +* This file is part of Maarch software. -/* -* Copyright 2017 Maarch -* -* This file is part of Maarch Framework. -* -* Maarch Framework is free software: you can redistribute it and/or modify -* it under the terms of the GNU General Public License as published by -* the Free Software Foundation, either version 3 of the License, or -* (at your option) any later version. -* -* Maarch Framework is distributed in the hope that it will be useful, -* but WITHOUT ANY WARRANTY; without even the implied warranty of -* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -* GNU General Public License for more details. -* -* You should have received a copy of the GNU General Public License -* along with Maarch Framework. If not, see <http://www.gnu.org/licenses/>. +* @brief merged_js +* @author dev <dev@maarch.org> +* @ingroup apps */ -include_once('../../core/init.php'); -include_once($_SESSION['config']['corepath'].DIRECTORY_SEPARATOR.'apps/maarch_entreprise'.DIRECTORY_SEPARATOR.'merged_jsAbstract.php'); +require_once '../../core/init.php'; +require_once $_SESSION['config']['corepath'].DIRECTORY_SEPARATOR.'apps/maarch_entreprise'.DIRECTORY_SEPARATOR.'merged_jsAbstract.php'; -class MergedJs extends MergedJsAbstract{ +class MergedJs extends MergedJsAbstract +{ // Your stuff her } diff --git a/apps/maarch_entreprise/merged_jsAbstract.php b/apps/maarch_entreprise/merged_jsAbstract.php index 59d80219e99afdbe1b0624af280fd7b48a0fccdb..80bdc8e12795b3dd6b8b3afdd08c23c10f78d2e8 100755 --- a/apps/maarch_entreprise/merged_jsAbstract.php +++ b/apps/maarch_entreprise/merged_jsAbstract.php @@ -1,109 +1,106 @@ -<?php - -/* -* Copyright 2017 Maarch -* -* This file is part of Maarch Framework. -* -* Maarch Framework is free software: you can redistribute it and/or modify -* it under the terms of the GNU General Public License as published by -* the Free Software Foundation, either version 3 of the License, or -* (at your option) any later version. -* -* Maarch Framework is distributed in the hope that it will be useful, -* but WITHOUT ANY WARRANTY; without even the implied warranty of -* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -* GNU General Public License for more details. -* -* You should have received a copy of the GNU General Public License -* along with Maarch Framework. If not, see <http://www.gnu.org/licenses/>. -*/ - -class MergedJsAbstract { - public function header() { - if ( empty($_GET['debug']) ) { - $date = mktime(0,0,0,date("m" ) + 2 ,date("d" ) ,date("Y" ) ); - $date = date("D, d M Y H:i:s", $date); - $time = 30*12*60*60; - header("Pragma: public"); - header("Expires: ".$date." GMT"); - header("Cache-Control: max-age=".$time.", must-revalidate"); - header('Content-type: text/javascript'); - } - } - public function start() { - ob_start(); - } - public function end() { - ob_end_flush(); - } - - public function merge_lib() { - readfile('apps/maarch_entreprise/js/prototype.js'); - - //scriptaculous (prototype) - readfile('apps/maarch_entreprise/js/scriptaculous.js'); - readfile('apps/maarch_entreprise/js/effects.js'); - readfile('apps/maarch_entreprise/js/controls.js'); - - //Dependencies - readfile('node_modules/jquery/dist/jquery.min.js'); - readfile('node_modules/core-js/client/shim.js'); //Angular - readfile('node_modules/zone.js/dist/zone.min.js'); //Angular - readfile('node_modules/bootstrap/dist/js/bootstrap.min.js'); - readfile('node_modules/chart.js/Chart.min.js'); - readfile('node_modules/tinymce/tinymce.min.js'); - readfile('node_modules/datatables/media/js/jquery.dataTables.min.js'); - readfile('node_modules/jquery.nicescroll/jquery.nicescroll.min.js'); - readfile('node_modules/tooltipster/dist/js/tooltipster.bundle.min.js'); - readfile('node_modules/jquery-typeahead/dist/jquery.typeahead.min.js'); - readfile('node_modules/hammerjs/hammer.min.js'); //Angular Material - readfile('apps/maarch_entreprise/js/chosen.jquery.min.js'); - readfile('apps/maarch_entreprise/js/bootstrap-tree.js'); - - //Mobile - readfile('node_modules/photoswipe/dist/photoswipe.min.js'); - readfile('node_modules/photoswipe/dist/photoswipe-ui-default.min.js'); - - //Maarch - include('apps/maarch_entreprise/js/functions.js'); - include('apps/maarch_entreprise/js/indexing.js'); - readfile('apps/maarch_entreprise/js/angularFunctions.js'); - - -// include('apps/maarch_entreprise/js/RSVP.js'); -// include('apps/maarch_entreprise/js/render.js'); -// include('apps/maarch_entreprise/js/jio.js'); - - - echo "\n"; - } - - public function merge_module() { - if ( !empty($_SESSION['modules_loaded'])) { - foreach(array_keys($_SESSION['modules_loaded']) as $value) - { - if(file_exists($_SESSION['config']['corepath'].'custom'.DIRECTORY_SEPARATOR.$_SESSION['custom_override_id'].DIRECTORY_SEPARATOR.'modules'.DIRECTORY_SEPARATOR.$_SESSION['modules_loaded'][$value]['name'].DIRECTORY_SEPARATOR."js".DIRECTORY_SEPARATOR."functions.js") - || file_exists($_SESSION['config']['corepath'].'modules'.DIRECTORY_SEPARATOR.$_SESSION['modules_loaded'][$value]['name'].DIRECTORY_SEPARATOR."js".DIRECTORY_SEPARATOR."functions.js")) - { - include('modules/'.$_SESSION['modules_loaded'][$value]['name'].'/js/functions.js'); - } - } - } - } - - public function merge() { - if ( empty($_GET['html'] ) ) { - $this->header(); - $this->start(); - $this->merge_lib(); - $this->merge_module(); - $this->end(); - } else { - echo '<html><body><script>'; - $this->merge_lib(); - $this->merge_module(); - echo '</script></body></html>';exit; - } - } -} +<?php +/** +* Copyright Maarch since 2008 under licence GPLv3. +* See LICENCE.txt file at the root folder for more details. +* This file is part of Maarch software. + +* @brief merged_jsAbstract +* @author dev <dev@maarch.org> +* @ingroup apps +*/ + +class MergedJsAbstract +{ + public function header() + { + if (empty($_GET['debug'])) { + $date = mktime(0, 0, 0, date("m") + 2, date("d"), date("Y")); + $date = date("D, d M Y H:i:s", $date); + $time = 30*12*60*60; + header("Pragma: public"); + header("Expires: ".$date." GMT"); + header("Cache-Control: max-age=".$time.", must-revalidate"); + header('Content-type: text/javascript'); + } + } + public function start() + { + ob_start(); + } + public function end() + { + ob_end_flush(); + } + + public function merge_lib() + { + readfile('apps/maarch_entreprise/js/prototype.js'); + + //scriptaculous (prototype) + readfile('apps/maarch_entreprise/js/scriptaculous.js'); + readfile('apps/maarch_entreprise/js/effects.js'); + readfile('apps/maarch_entreprise/js/controls.js'); + + //Dependencies + readfile('node_modules/jquery/dist/jquery.min.js'); + readfile('node_modules/core-js/client/shim.js'); //V2 - Angular + readfile('node_modules/zone.js/dist/zone.min.js'); //V2 - Angular + readfile('node_modules/bootstrap/dist/js/bootstrap.min.js'); //V2 + readfile('node_modules/chart.js/Chart.min.js'); + readfile('node_modules/tinymce/tinymce.min.js'); + readfile('node_modules/jquery.nicescroll/jquery.nicescroll.min.js'); //V2 + readfile('node_modules/tooltipster/dist/js/tooltipster.bundle.min.js'); //V2 + readfile('node_modules/jquery-typeahead/dist/jquery.typeahead.min.js'); //V2 + readfile('node_modules/hammerjs/hammer.min.js'); //V2- Angular Material + readfile('apps/maarch_entreprise/js/chosen.jquery.min.js'); + readfile('node_modules/jstree-bootstrap-theme/dist/jstree.js'); //V2 + readfile('apps/maarch_entreprise/js/bootstrap-tree.js'); //DEPRECATED use jstree instead + + //Mobile + readfile('node_modules/photoswipe/dist/photoswipe.min.js'); + readfile('node_modules/photoswipe/dist/photoswipe-ui-default.min.js'); + + //Maarch + include 'apps/maarch_entreprise/js/functions.js'; + include 'apps/maarch_entreprise/js/indexing.js'; + readfile('apps/maarch_entreprise/js/angularFunctions.js'); + + + // include('apps/maarch_entreprise/js/RSVP.js'); + // include('apps/maarch_entreprise/js/render.js'); + // include('apps/maarch_entreprise/js/jio.js'); + + + echo "\n"; + } + + public function merge_module() + { + if (!empty($_SESSION['modules_loaded'])) { + foreach (array_keys($_SESSION['modules_loaded']) as $value) { + + if (file_exists($_SESSION['config']['corepath'].'custom'.DIRECTORY_SEPARATOR.$_SESSION['custom_override_id'].DIRECTORY_SEPARATOR.'modules'.DIRECTORY_SEPARATOR.$_SESSION['modules_loaded'][$value]['name'].DIRECTORY_SEPARATOR."js".DIRECTORY_SEPARATOR."functions.js") + || file_exists($_SESSION['config']['corepath'].'modules'.DIRECTORY_SEPARATOR.$_SESSION['modules_loaded'][$value]['name'].DIRECTORY_SEPARATOR."js".DIRECTORY_SEPARATOR."functions.js") + ) { + include 'modules/'.$_SESSION['modules_loaded'][$value]['name'].'/js/functions.js'; + } + } + } + } + + public function merge() + { + if (empty($_GET['html'])) { + $this->header(); + $this->start(); + $this->merge_lib(); + $this->merge_module(); + $this->end(); + } else { + echo '<html><body><script>'; + $this->merge_lib(); + $this->merge_module(); + echo '</script></body></html>';exit; + } + } +} diff --git a/apps/maarch_entreprise/my_contacts/setContactType.php b/apps/maarch_entreprise/my_contacts/setContactType.php index 48fe5a820627b61a8acfad7a65c639742e8f5b2e..f797166cbc6e94cfcfb354d217eddd93677fdf7a 100755 --- a/apps/maarch_entreprise/my_contacts/setContactType.php +++ b/apps/maarch_entreprise/my_contacts/setContactType.php @@ -24,7 +24,6 @@ $core->test_user(); require_once 'core/class/class_db_pdo.php'; $db = new Database(); - if ($_POST['contact_target'] == "") { $_POST['contact_target'] = "corporate"; } @@ -57,6 +56,8 @@ while($res = $stmt->fetchObject()){ $iCount++; } - +if($stmt->rowCount()==0){ + echo "false"; +} echo $frmStr; exit; diff --git a/apps/maarch_entreprise/reports/get_report_by_period_val.php b/apps/maarch_entreprise/reports/get_report_by_period_val.php index 373cfd328545bc45772a8c49ace05091f8bb59bb..0ec2eb33d5b4a609d5dd3fc39a0c79e5a2456e02 100755 --- a/apps/maarch_entreprise/reports/get_report_by_period_val.php +++ b/apps/maarch_entreprise/reports/get_report_by_period_val.php @@ -27,11 +27,11 @@ $core_tools = new core_tools(); $core_tools->test_user(); $core_tools->load_lang(); $core_tools->test_service('reports', 'reports'); -$db = new Database(); -$req = new request(); -$list = new list_show(); +$db = new Database(); +$req = new request(); +$list = new list_show(); $graph = new graphics(); -$sec = new security(); +$sec = new security(); $_ENV['date_pattern'] = "/^[0-3][0-9]-[0-1][0-9]-[1-2][0-9][0-9][0-9]$/"; @@ -43,10 +43,23 @@ $where_status = ''; if (!empty($_POST['entities_chosen'])) { $entities_chosen = explode("#", $_POST['entities_chosen']); + if($_REQUEST['sub_entities'] == 'true'){ + $sub_entities = []; + foreach($entities_chosen as $value){ + $sub_entities[] = users_entities_Abstract::getEntityChildren($value); + } + $sub_entities1 = "'"; + $countSubEntities = count($sub_entities); + for( $i=0; $i< $countSubEntities; $i++){ + $sub_entities1 .= implode("','",$sub_entities[$i]); + $sub_entities1 .= "','"; + } + $sub_entities1 = substr($sub_entities1, 0, -2); + } $entities_chosen = "'" . join("','", $entities_chosen) . "'"; $where_entities = ' AND destination in (' . $entities_chosen . ') '; if($_REQUEST['sub_entities'] == 'true'){ - $where_entities = 'AND (destination in (' . $entities_chosen . ') or destination in (select entity_id from entities where parent_entity_id IN ('.$entities_chosen.')))'; + $where_entities = 'AND (destination in (' . $entities_chosen . ') or destination in ('.$sub_entities1.'))'; } } @@ -706,7 +719,6 @@ else $totalCourrier=array(); $totalEntities = count($entities); - foreach(array_keys($_SESSION['coll_categories']['letterbox_coll']) as $key) { if($key!='default_category'){ diff --git a/apps/maarch_entreprise/template/documents_list_attachments.html b/apps/maarch_entreprise/template/documents_list_attachments.html index 1dadf6a94451815c83947d7073f6c70c32ae951f..3e8e8dfc72fecbeb733d4658a98ada81c47277ec 100755 --- a/apps/maarch_entreprise/template/documents_list_attachments.html +++ b/apps/maarch_entreprise/template/documents_list_attachments.html @@ -64,12 +64,12 @@ Mods <br/> ##sortColumn|identifier## </div> - <div style="white-space: nowrap;display: table-cell;text-align: center;padding-left: 10px;float:left;"> + <div style="white-space: nowrap;display: table-cell;text-align: center;padding-left: 30px;float:left;"> ##defineLang|_TYPES## <br/> ##sortColumn|attachment_type## </div> - <div style="white-space: nowrap;display: table-cell;text-align: center;padding-left: 10px;float:left;"> + <div style="white-space: nowrap;display: table-cell;text-align: center;padding-left: 25px;float:left;"> ##defineLang|_OBJECT## <br/> ##sortColumn|title## @@ -84,17 +84,17 @@ Mods <br/> ##sortColumn|creation_date## </div> - <div style="white-space: nowrap;display: table-cell;text-align: center;padding-left: 10px;float:left;"> + <div style="white-space: nowrap;display: table-cell;text-align: center;padding-left: 55px;float:left;"> ##defineLang|_UPDATED_DATE## <br/> ##sortColumn|doc_date## </div> - <div style="white-space: nowrap;display: table-cell;text-align: center;padding-left: 10px;float:left;"> + <div style="white-space: nowrap;display: table-cell;text-align: center;padding-left: 55px;float:left;"> ##defineLang|_MODIFY_BY## <br/> ##sortColumn|updated_by## </div> - <div style="white-space: nowrap;display: table-cell;text-align: center;padding-left: 10px;float:left;"> + <div style="white-space: nowrap;display: table-cell;text-align: center;padding-left: 87px;float:left;"> ##defineLang|_BACK_DATE## <br/> ##sortColumn|validation_date## @@ -157,8 +157,8 @@ Mods <tr class="##cssLine|col|white ##" > <td width="15%" style="text-align:center"> - <table width="100%" border="0" cellspacing="0" cellpadding="0" > - <tr> + <table width="85%" border="0" cellspacing="0" cellpadding="0" > + <tr style="left: 5%;position: relative;"> <!--<td style="text-align:center;width:25px"><b title="##defineLang|_VERSION##">##loadValue|relation##</b></td>--> <td style="text-align:center;width:100px"> <b title="##defineLang|_CHRONO_NUMBER##">##loadValue|identifier##</b><br/> @@ -186,15 +186,17 @@ Mods </td> </tr> <tr class="##cssLineReload##"> - <td width="15%" style="text-align:center"> - <table width="100%" border="0" cellspacing="0" cellpadding="0" > - <tr> - <td width="40%">##showIconDocument##</td> - <td width="15%"> + <td width="15%" > + <table width="85%" border="0" cellspacing="0" cellpadding="0" > + <tr > + <td width="40%" style="text-align:right"> <i style="font-size:10px;color:#16ADEB;" title="##defineLang|_VERSION##">##loadValue|relation##</i> <i style="color:#16ADEB;">##func_previous_version##</i> </td> - <td width="45%" style="text-align:center;font-size:13px;width:100px" title="##defineLang|_STATUS##"><i>##loadValue|status##</i></td> + <td width="65%" style="text-align:left;" title="##defineLang|_STATUS##"> + <i>##loadValue|status##</i> + </td> + <!--<td width="45%" style="text-align:center;font-size:13px;width:100px" title="##defineLang|_STATUS##"></td>--> </tr> </table> </td> @@ -209,16 +211,22 @@ Mods <td width="11%" style="text-align:right">##func_previous_version##</td> </table> </td>--> - <td style="text-align:left;width:20%;" title="##defineLang|_CREATION_DATE##"><i class="fa fa-calendar"></i> + <td style="text-align:left;width:17%;" title="##defineLang|_CREATION_DATE##"><i class="fa fa-calendar"></i> ##loadValue|creation_date##</td> <td style="text-align:left;width:20%;" title="##defineLang|_UPDATED_DATE##"><i class="fa fa-calendar-check-o"></i> - ##loadValue|doc_date##<i title="##defineLang|_MODIFY_BY##" style="font-size:10px;cursor: pointer;"> ##defineLang|_MODIFY_BY## : ##loadValue|updated_by##</i></td> + ##loadValue|doc_date##<i title="##defineLang|_MODIFY_BY##" style="font-size:10px;cursor: pointer;padding-left:35px"> ##defineLang|_MODIFY_BY## : ##loadValue|updated_by##</i></td> <!--<td style="text-align:left" width="17%" title="##defineLang|_TYPIST##">##loadValue|typist##</td>--> <!--<td style="text-align:center" width="10%">##loadValue|doc_date##</td>--> - <td style="text-align:left;width:20%;" title="##defineLang|_BACK_DATE##"><i class="fa fa-calendar-times-o"></i> + <td style="text-align:center;width:10%;" title="##defineLang|_BACK_DATE##"><i class="fa fa-calendar-times-o"></i> ##loadValue|validation_date##</td> - <td style="text-align:right;width:200px;">##func_final_version## - ##func_modify## ##func_delete##</td> + <td style="text-align:right;width:200px;"><table width="100%" border="0" cellspacing="0" cellpadding="0"> + <tbody> + <tr> + <td style="width:30%;text-align:right;">##func_final_version##</td> + <td style="width:10%;text-align:right;padding-bottom:5px;">##func_modify## ##func_delete##</td> + <td style="width:1%;text-align:right;">##showIconDocument##</td> + </tr> + </tbody></table> </td> <!--<td style="text-align:left" width="17%">##loadValue|updated_by##</td>--> </tr> </table> diff --git a/apps/maarch_entreprise/template/documents_list_search_adv.html b/apps/maarch_entreprise/template/documents_list_search_adv.html index 35aec327338ea392e2664c5bf2150b5332d73b33..97cf5799706f76306dc162e7d4f08410544fb690 100755 --- a/apps/maarch_entreprise/template/documents_list_search_adv.html +++ b/apps/maarch_entreprise/template/documents_list_search_adv.html @@ -153,7 +153,7 @@ Mods <td style="font-size:10px;" width ="30px">##func_bool_see_notes##</td> <td style="font-size:10px;" width ="30px">##showActionAdvResultFA|#defineLang|_ATTACHMENTS#|paperclip|loadRepList('#loadValue|res_id#', 'FT')|#loadValue|count_attachment# == 0##</td> <td style="font-size:10px;" width ="30px">##showActionFA|#defineLang|_WF#|gear|loadDiffList('#loadValue|res_id#')##</td> - <td style="font-size:10px;" width ="30px" >##showIconDocument##</td> + <td style="font-size:10px;" width ="30px" >##ifStatement|'#loadValue|filename#'!=null|#showIconDocument#|## </td> <td style="font-size:10px;" width ="30px" >##showIconDetails##</td> </tr> </table> diff --git a/apps/maarch_entreprise/template/documents_list_with_attachments.html b/apps/maarch_entreprise/template/documents_list_with_attachments.html index 5c4229dd3aa84e0dd07c2d91f5a1eefabe4fda17..4085a5765adc8f34f6e1ed3515d505513740c151 100755 --- a/apps/maarch_entreprise/template/documents_list_with_attachments.html +++ b/apps/maarch_entreprise/template/documents_list_with_attachments.html @@ -156,7 +156,7 @@ Mods <td style="font-size:10px;" width ="30px">##func_bool_see_notes##</td> <td style="font-size:10px;" width ="30px">##showActionBasketsFA|#defineLang|_ATTACHMENTS#|paperclip|loadRepList('#loadValue|res_id#', 'baskets')|#loadValue|count_attachment# == 0##</td> <td style="font-size:10px;" width ="30px">##showActionFA|#defineLang|_WF#|gear|loadDiffList('#loadValue|res_id#')##</td> - <td style="font-size:10px;" width ="30px" >##showIconDocument##</td> + <td style="font-size:10px;" width ="30px" >##ifStatement|'#loadValue|filename#'!=null|#showIconDocument#|##</td> <td style="font-size:10px;" width ="30px" >##showIconDetails##</td> </tr> </table> diff --git a/apps/maarch_entreprise/template/header.html b/apps/maarch_entreprise/template/header.html index dfe9bd3797ed44e04021c21582891c4c37db7292..c97bb7886cb6dec288f4646eb3fa812517650dad 100755 --- a/apps/maarch_entreprise/template/header.html +++ b/apps/maarch_entreprise/template/header.html @@ -1,5 +1,28 @@ +<?php +require_once 'core/Models/UserModel.php'; +?> <div id="header"> <div id="nav"> + <div id="header_username" style="position:absolute;text-align:center;left:45%;font-size: 1.3em;top: 6px;color: white; font-size:14px; line-height: 1; font-family:Verdana,Geneva,Arial,Helvetica,sans-serif"> + <?php + $strUserInfos = $_SESSION['user']['FirstName']." ".$_SESSION['user']['LastName']; + $userGroups=\Core\Models\UserModel::getGroupsByUserId(['userId'=> $_SESSION['user']['UserId']]); + + if(!empty($userGroups)){ + $strUserInfos.=" ("; + for($i=0;$i<count($userGroups);$i++){ + if($i==count($userGroups)-1){ + $strUserInfos.=$userGroups[$i]['group_desc']; + } else { + $strUserInfos.=$userGroups[$i]['group_desc'].", "; + } + } + $strUserInfos.=")"; + } + + echo $strUserInfos; + ?> + </div> <div id="menu" onmouseover="ShowHideMenu('menunav','on');" onmouseout="ShowHideMenu('menunav','off');" class="off"> <p> <span style="background:url('');background-position: 10px 0px;background-size:25%; diff --git a/apps/maarch_entreprise/xml/IVS/validation_rules.xml b/apps/maarch_entreprise/xml/IVS/validation_rules.xml index 08ef49ce0a21a0f0e67653f8dedd968a2cc85a83..a65534200f29e7581d412770b61102bdfd2ccd7d 100755 --- a/apps/maarch_entreprise/xml/IVS/validation_rules.xml +++ b/apps/maarch_entreprise/xml/IVS/validation_rules.xml @@ -471,6 +471,8 @@ <parameter name="identifier" type="string" /> <parameter name="services_chosen" type="identifier" /> <parameter name="services_available" type="identifier" /> + <parameter name="initiatorServices_chosen" type="identifier" /> + <parameter name="initiatorServices_available" type="identifier" /> <parameter name="market" type="string" /> <parameter name="status_chosen" type="identifier" /> <parameter name="status_available" type="identifier" /> diff --git a/apps/maarch_entreprise/xml/services.xml b/apps/maarch_entreprise/xml/services.xml index a384e9659a08aba4bd27fd08ecbbe3fe4278c2d0..4f9c63bb158c1e8317f8bbfc70f48dc9d01fafd2 100755 --- a/apps/maarch_entreprise/xml/services.xml +++ b/apps/maarch_entreprise/xml/services.xml @@ -67,21 +67,23 @@ <id>view_history</id> <name>_VIEW_HISTORY</name> <comment>_VIEW_HISTORY_DESC</comment> - <servicepage>index.php?page=history&admin=history</servicepage> + <servicepage>/administration/history</servicepage> <servicetype>admin</servicetype> <system_service>false</system_service> <style>fa fa-history</style> <enabled>true</enabled> + <angular>true</angular> </SERVICE> <SERVICE> <id>view_history_batch</id> <name>_VIEW_HISTORY_BATCH</name> <comment>_VIEW_HISTORY_BATCH_DESC</comment> - <servicepage>index.php?page=history_batch&admin=history_batch</servicepage> + <servicepage>/administration/historyBatch</servicepage> <servicetype>admin</servicetype> <system_service>false</system_service> <style>fa fa-history</style> <enabled>true</enabled> + <angular>true</angular> </SERVICE> <!--<SERVICE> <id>xml_param_services</id> diff --git a/core/Controllers/ActionsController.php b/core/Controllers/ActionsController.php index fa321e9062364a036f4c9a9601b6d9fb23eb08d9..65a23db241469bfe619c5f5032c6fe45b423c308 100755 --- a/core/Controllers/ActionsController.php +++ b/core/Controllers/ActionsController.php @@ -63,6 +63,11 @@ class ActionsController $obj['action']['create_id'] = false; } + //array of id categoriesList + foreach ($obj['action']['actionCategories'] as $key => $category) { + $arrActionCategories[] = $category['category_id']; + } + $obj['action']['actionCategories'] = $arrActionCategories; $obj['categoriesList'] = ActionsModel:: getLettersBoxCategories(); @@ -70,23 +75,10 @@ class ActionsController foreach ($obj['categoriesList'] as $key => $category) { $arrCategoriesList[] = $category['id']; } + //array of id actionCategories - if (!empty($obj['action']['actionCategories'])) { - foreach ($obj['action']['actionCategories'] as $actionCategories) { - $arrActionCategories[] = $actionCategories['category_id']; - } - //check - foreach ($arrActionCategories as $key => $category_id) { - if (in_array($category_id, $arrCategoriesList)) { - $obj['categoriesList'][$key]['selected'] = true; - } else { - $obj['categoriesList'][$key]['selected'] = false; - } - } - } else { - foreach ($obj['categoriesList'] as $key => $category) { - $obj['categoriesList'][$key]['selected'] = false; - } + if (empty($obj['action']['actionCategories'])) { + $obj['action']['actionCategories'] = $arrCategoriesList; } $obj['statusList'] = StatusModel::getList(); @@ -94,7 +86,6 @@ class ActionsController $obj['action_pagesList']=ActionsModel::getAction_pages(); array_unshift($obj['action_pagesList']['actionsPageList'], ['id'=>'','label'=> _NO_PAGE, 'name'=>'', 'origin'=>'']); $obj['keywordsList']=ActionsModel::getKeywords(); - $obj['lang'] = LangModel::getActionsForAdministrationLang(); return $response->withJson($obj); } @@ -184,11 +175,10 @@ class ActionsController ->withJson(['errors' => _NOT_DELETE]); } - return $response->withJson( [ 'success' => _ACTION. ' <b>' . $id .'</b> ' ._DELETED, - 'action' => $obj + 'action' => ActionsModel::getList() ] ); } diff --git a/core/Controllers/CoreController.php b/core/Controllers/CoreController.php index b7c8bac5614ec99829e107b12092bd216c6c896f..a66b75f64e27d9afa821e5facdeb51600f9d5f5a 100755 --- a/core/Controllers/CoreController.php +++ b/core/Controllers/CoreController.php @@ -37,7 +37,7 @@ class CoreController if (!empty($data['views'])) { foreach ($data['views'] as $view) { $aInit[$view . 'View'] = 'Views/' . $view . '.component.html'; - if(file_exists("custom/{$customId}/apps/maarch_entreprise/Views/{$view}.component.html")) { + if (file_exists("custom/{$customId}/apps/maarch_entreprise/Views/{$view}.component.html")) { $aInit[$view . 'View'] = "../../custom/{$customId}/apps/maarch_entreprise/Views/{$view}.component.html"; } } @@ -50,6 +50,7 @@ class CoreController { if ($_SESSION['user']['UserId'] == 'superadmin') { //TODO session $administration = []; + $administration['menu'] = ServiceModel::getApplicationAdministrationMenuByXML(); $administration['application'] = ServiceModel::getApplicationAdministrationServicesByXML(); $administration['modules'] = ServiceModel::getModulesAdministrationServicesByXML(); } else { diff --git a/core/Controllers/HistoryController.php b/core/Controllers/HistoryController.php index 27c1815743145900ec20e48703b30e0a08704c85..eec4dd47aac0d5b77e7b955217ea23e091db2dbb 100755 --- a/core/Controllers/HistoryController.php +++ b/core/Controllers/HistoryController.php @@ -21,6 +21,7 @@ use Psr\Http\Message\RequestInterface; use Psr\Http\Message\ResponseInterface; use Respect\Validation\Validator; use Core\Models\HistoryModel; +use Core\Models\ServiceModel; use Core\Models\ValidatorModel; use Notifications\Controllers\NotificationsEventsController; @@ -245,4 +246,35 @@ class HistoryController return $pathToXml; } + + public function getForAdministration(RequestInterface $request, ResponseInterface $response, $aArgs) + { + if (!ServiceModel::hasService(['id' => 'history', 'userId' => $_SESSION['user']['UserId'], 'location' => 'apps', 'type' => 'admin'])) { + return $response->withStatus(403)->withJson(['errors' => 'Service forbidden']); + } + $return = []; + $historyList = HistoryModel::getHistoryList(['event_date' => $aArgs['date']]); + $historyListFilters['users'] = HistoryModel::getFilter(['select' => 'user_id','event_date' => $aArgs['date']]); + $historyListFilters['eventType'] = HistoryModel::getFilter(['select' => 'event_type','event_date' => $aArgs['date']]); + + $return['filters'] = $historyListFilters; + $return['historyList'] = $historyList; + + return $response->withJson($return); + } + + public function getBatchForAdministration(RequestInterface $request, ResponseInterface $response, $aArgs) + { + if (!ServiceModel::hasService(['id' => 'view_history_batch', 'userId' => $_SESSION['user']['UserId'], 'location' => 'apps', 'type' => 'admin'])) { + return $response->withStatus(403)->withJson(['errors' => 'Service forbidden']); + } + $return = []; + $historyList = HistoryModel::getHistoryBatchList(['event_date' => $aArgs['date']]); + $historyListFilters['modules'] = HistoryModel::getBatchFilter(['select' => 'module_name','event_date' => $aArgs['date']]); + + $return['filters'] = $historyListFilters; + $return['historyList'] = $historyList; + + return $response->withJson($return); + } } diff --git a/core/Controllers/ParametersController.php b/core/Controllers/ParametersController.php index fd7a879899674a860c18779a26b187f7bd0c2067..322567bbb5cbe451eed6919e7d3f019a0b20779d 100755 --- a/core/Controllers/ParametersController.php +++ b/core/Controllers/ParametersController.php @@ -84,7 +84,7 @@ class ParametersController return $response->withJson( [ - 'success' => _PARAMETER. ' <b>' . $obj['id'] .'</b> ' ._ADDED, + 'success' => _PARAMETER. ' <b>' . $obj['id'] .'</b> ' ._ADDED ] ); } @@ -123,6 +123,7 @@ class ParametersController return $response->withJson( [ 'success' => _PARAMETER. ' <b>' . $aArgs['id'] .'</b> ' ._DELETED, + 'parameters' => ParametersModel::getList() ] ); } diff --git a/core/Controllers/ResController.php b/core/Controllers/ResController.php index 3b437330d4bae99ebfe13301e7011ea8556c026c..c40325dee5200b2799a15db79d1717e7bf786c88 100755 --- a/core/Controllers/ResController.php +++ b/core/Controllers/ResController.php @@ -34,12 +34,37 @@ class ResController { public function create(RequestInterface $request, ResponseInterface $response, $aArgs) { - if(empty($aArgs)){ + if(empty($aArgs)) { + $aArgs = $request->getQueryParams(); + $aArgs['data'] = json_decode($aArgs['data']); + $aArgs['data'] = $this->object2array($aArgs['data']); + + //FIX pb if data has parent + if (isset($aArgs['data']['data'])) { + $aArgs['data'] = $aArgs['data']['data']; + } } + //***************************************************************************************** + //LOG ONLY LOG FOR DEBUG + // $file = fopen('storeResourceLogs.log', a); + // fwrite($file, '[' . date('Y-m-d H:i:s') . '] new request' . PHP_EOL); + // foreach ($aArgs as $key => $value) { + // if ($key <> 'encodedFile') { + // fwrite($file, '[' . date('Y-m-d H:i:s') . '] ' . $key . ' : ' . $value . PHP_EOL); + // } + // } + // fclose($file); + // ob_flush(); + // ob_start(); + // print_r($aArgs['data']); + // file_put_contents("storeResourceLogs.log", ob_get_flush()); + //END LOG FOR DEBUG ONLY + //***************************************************************************************** + $return = $this->storeResource($aArgs); if ($return['errors']) { @@ -49,8 +74,11 @@ class ResController ['errors' => _NOT_CREATE . ' ' . $return['errors']] ); } + + //standardize ws response for MaarchCapture + $wsReturn['resId'] = $return[0]; - return $response->withJson($return); + return $response->withJson($wsReturn); } public function delete(RequestInterface $request, ResponseInterface $response, $aArgs) @@ -158,7 +186,8 @@ class ResController $returnCode = 0; //copy sended file on tmp - $fileContent = base64_decode($encodedFile); + //$fileContent = base64_decode($encodedFile); + $fileContent = base64_decode(str_replace(array('-', '_'), array('+', '/'), $encodedFile)); $random = rand(); $fileName = 'tmp_file_' . $random . '.' . $fileFormat; $Fnm = CoreConfigModel::getTmpPath() . $fileName; @@ -419,7 +448,7 @@ class ResController } $resInsert = ResModel::create([ - 'table' => 'res_letterbox', + 'table' => $table, 'data' => $prepareData ]); diff --git a/core/Controllers/ResExtController.php b/core/Controllers/ResExtController.php index b1ef7784535b8304c2ed34368e3ab80be7835fd8..8bee0e0f90e9f05e8ab8ed50ed3a34e6378418cd 100755 --- a/core/Controllers/ResExtController.php +++ b/core/Controllers/ResExtController.php @@ -27,12 +27,37 @@ class ResExtController { public function create(RequestInterface $request, ResponseInterface $response, $aArgs) { - if(empty($aArgs)){ + if(empty($aArgs)) { + $aArgs = $request->getQueryParams(); + $aArgs['data'] = json_decode($aArgs['data']); + $aArgs['data'] = $this->object2array($aArgs['data']); + + //FIX pb if data has parent + if (isset($aArgs['data']['data'])) { + $aArgs['data'] = $aArgs['data']['data']; + } } + //***************************************************************************************** + //LOG ONLY LOG FOR DEBUG + // $file = fopen('storeResourceLogs.log', a); + // fwrite($file, '[' . date('Y-m-d H:i:s') . '] new request' . PHP_EOL); + // foreach ($aArgs as $key => $value) { + // if ($key <> 'encodedFile') { + // fwrite($file, '[' . date('Y-m-d H:i:s') . '] ' . $key . ' : ' . $value . PHP_EOL); + // } + // } + // fclose($file); + // ob_flush(); + // ob_start(); + // print_r($aArgs['data']); + // file_put_contents("storeResourceLogs.log", ob_get_flush()); + //END LOG FOR DEBUG ONLY + //***************************************************************************************** + $return = $this->storeExtResource($aArgs); if ($return['errors']) { @@ -43,7 +68,10 @@ class ResExtController ); } - return $response->withJson([$return]); + //standardize ws response for MaarchCapture + $wsReturn['status'] = $return; + + return $response->withJson($wsReturn); } public function delete(RequestInterface $request, ResponseInterface $response, $aArgs) diff --git a/core/Controllers/StatusController.php b/core/Controllers/StatusController.php index 861c91f2bbcbc31127d7e7c2b3a916f8a7cb198c..89e189b76e75eb78e2b83b6f55f7b5b2ae2870f6 100755 --- a/core/Controllers/StatusController.php +++ b/core/Controllers/StatusController.php @@ -31,8 +31,7 @@ class StatusController } return $response->withJson([ - 'statusList' => StatusModel::getList(), - 'lang' => StatusModel::getStatusLang() + 'statusList' => StatusModel::getList() ]); } @@ -43,8 +42,7 @@ class StatusController } return $response->withJson([ - 'statusImages' => StatusImagesModel::getStatusImages(), - 'lang' => StatusModel::getStatusLang() + 'statusImages' => StatusImagesModel::getStatusImages() ]); } @@ -147,9 +145,8 @@ class StatusController $statusDeleted = StatusModel::getByIdentifier(['identifier' => $aArgs['identifier']]); if (Validator::notEmpty()->validate($aArgs['identifier']) && Validator::numeric()->validate($aArgs['identifier']) && !empty($statusDeleted)) { - $return = [ - StatusModel::delete(['identifier' => $aArgs['identifier']]) - ]; + + StatusModel::delete(['identifier' => $aArgs['identifier']]); HistoryController::add([ 'table_name' => 'status', @@ -164,7 +161,11 @@ class StatusController ->withJson(['errors' => 'identifier not valid']); } - return $response->withJson($return); + return $response->withJson( + [ + 'statuses' => StatusModel::getList() + ] + ); } protected function manageValue($request) diff --git a/core/Controllers/UserController.php b/core/Controllers/UserController.php index d42ba1c60dcca2ce7b4e659ecf76b2853e0297ed..36c75cc9a3d55f04fe3b74256da7b9e8a0e0dd42 100755 --- a/core/Controllers/UserController.php +++ b/core/Controllers/UserController.php @@ -15,18 +15,19 @@ namespace Core\Controllers; -use Core\Models\CoreConfigModel; -use Core\Models\SecurityModel; -use Psr\Http\Message\RequestInterface; -use Psr\Http\Message\ResponseInterface; -use Respect\Validation\Validator; use Baskets\Models\BasketsModel; +use Core\Models\CoreConfigModel; use Core\Models\GroupModel; +use Core\Models\HistoryModel; use Core\Models\LangModel; +use Core\Models\SecurityModel; use Core\Models\ServiceModel; -use Entities\Models\EntityModel; use Core\Models\UserModel; +use Entities\Models\EntityModel; use Entities\Models\ListModelsModel; +use Psr\Http\Message\RequestInterface; +use Psr\Http\Message\ResponseInterface; +use Respect\Validation\Validator; include_once 'core/class/docservers_controler.php'; @@ -41,7 +42,7 @@ class UserController $user['groups'] = UserModel::getGroupsByUserId(['userId' => $_SESSION['user']['UserId']]); $user['entities'] = UserModel::getEntitiesById(['userId' => $_SESSION['user']['UserId']]); $user['baskets'] = BasketsModel::getBasketsByUserId(['userId' => $_SESSION['user']['UserId']]); - + return $response->withJson($user); } @@ -69,7 +70,7 @@ class UserController UserModel::create(['user' => $data]); - $newUser = UserModel::getByUserId(['userId' => $data['userId'], 'select' => ['id']]); + $newUser = UserModel::getByUserId(['userId' => $data['userId']]); if (!Validator::intType()->notEmpty()->validate($newUser['id'])) { return $response->withStatus(500)->withJson(['errors' => 'User Creation Error']); } @@ -112,7 +113,53 @@ class UserController UserModel::delete(['id' => $aArgs['id']]); - return $response->withJson(['success' => _DELETED_USER]); + //get New User List + if ($_SESSION['user']['UserId'] == 'superadmin') { + $users = UserModel::get( + [ + 'select' => ['id', 'user_id', 'firstname', 'lastname', 'status', 'enabled', 'mail'], + 'where' => ['user_id != ?', 'status != ?'], + 'data' => ['superadmin', 'DEL'] + ] + ); + } else { + $entities = EntityModel::getAllEntitiesByUserId(['userId' => $_SESSION['user']['UserId']]); + $users = UserModel::getByEntities( + [ + 'select' => ['DISTINCT users.id', 'users.user_id', 'firstname', 'lastname', 'status', 'enabled', 'mail'], + 'entities' => $entities + ] + ); + } + + $usersId = []; + foreach ($users as $value) { + $usersId[] = $value['user_id']; + } + + $listModels = ListModelsModel::getDiffListByUsersId(['select' => ['item_id'], 'users_id' => $usersId, 'object_type' => 'entity_id', 'item_mode' => 'dest']); + + $usersListModels = []; + foreach ($listModels as $value) { + $usersListModels[] = $value['item_id']; + } + + foreach ($users as $key => $value) { + if (in_array($value['user_id'], $usersListModels)) { + $users[$key]['inDiffListDest'] = 'Y'; + } else { + $users[$key]['inDiffListDest'] = 'N'; + } + } + $users; + + + return $response->withJson( + [ + 'success' => _DELETED_USER, + 'users' => $users + ] + ); } public function updateProfile(RequestInterface $request, ResponseInterface $response) @@ -218,7 +265,7 @@ class UserController if (!empty($data['status']) && $data['status'] == 'OK') { $user = UserModel::getById(['id' => $aArgs['id'], 'select' => ['user_id', 'firstname', 'lastname']]); - UserModel::deactivateAbsenceById(['id' => $aArgs['id']]); + UserModel::desactivateAbsenceById(['id' => $aArgs['id']]); HistoryController::add([ 'table_name' => 'users', 'record_id' => $user['user_id'], @@ -476,8 +523,7 @@ class UserController $users[$key]['inDiffListDest'] = 'N'; } } - - $return['lang'] = LangModel::getUsersAdministrationLang(); + $return['users'] = $users; return $response->withJson($return); @@ -498,6 +544,7 @@ class UserController $user['entities'] = UserModel::getEntitiesById(['userId' => $user['user_id']]); $user['allEntities'] = EntityModel::getAvailableEntitiesForAdministratorByUserId(['userId' => $user['user_id'], 'administratorUserId' => $_SESSION['user']['UserId']]); $user['baskets'] = BasketsModel::getBasketsByUserId(['userId' => $user['user_id']]); + $user['history'] = HistoryModel::getHistoryByUserId(['userId' => $user['user_id']]); return $response->withJson($user); } @@ -528,7 +575,8 @@ class UserController return $response->withJson([ 'success' => _ADDED_GROUP, 'groups' => UserModel::getGroupsByUserId(['userId' => $user['user_id']]), - 'allGroups' => GroupModel::getAvailableGroupsByUserId(['userId' => $user['user_id']]) + 'allGroups' => GroupModel::getAvailableGroupsByUserId(['userId' => $user['user_id']]), + 'baskets' => BasketsModel::getBasketsByUserId(['userId' => $user['user_id']]) ]); } diff --git a/core/Models/GroupModelAbstract.php b/core/Models/GroupModelAbstract.php index 5c6f4148f166a02cf8e19c303ecae9ef3fb73d71..c3c2abb59a032d8e87d13baf23287c8da22962dc 100755 --- a/core/Models/GroupModelAbstract.php +++ b/core/Models/GroupModelAbstract.php @@ -23,7 +23,8 @@ class GroupModelAbstract 'select' => empty($aArgs['select']) ? ['*'] : $aArgs['select'], 'table' => ['usergroups'], 'where' => ['enabled = ?'], - 'data' => ['Y'] + 'data' => ['Y'], + 'order_by' => ['group_desc'] ]); return $aGroups; diff --git a/core/Models/HistoryModelAbstract.php b/core/Models/HistoryModelAbstract.php index da8f17756d0a79852e6d10c20939c02c0113339e..a973d6f203f8034ebc669126058c7152130cd301 100755 --- a/core/Models/HistoryModelAbstract.php +++ b/core/Models/HistoryModelAbstract.php @@ -115,4 +115,88 @@ class HistoryModelAbstract return $aReturn; } + + public static function getHistoryList(array $aArgs = []) + { + ValidatorModel::notEmpty($aArgs, ['event_date']); + + $aReturn = DatabaseModel::select( + [ + 'select' => empty($aArgs['select']) ? ['*'] : $aArgs['select'], + 'table' => ['history'], + 'where' => ["event_date >= date '".$aArgs['event_date']."'","event_date < date '".$aArgs['event_date']."' + interval '1 month'"], + 'order_by' => ['event_date DESC'] + ] + ); + + return $aReturn; + } + + public static function getHistoryBatchList(array $aArgs = []) + { + ValidatorModel::notEmpty($aArgs, ['event_date']); + + $aReturn = DatabaseModel::select( + [ + 'select' => empty($aArgs['select']) ? ['*'] : $aArgs['select'], + 'table' => ['history_batch'], + 'where' => ["event_date >= date '".$aArgs['event_date']."'","event_date < date '".$aArgs['event_date']."' + interval '1 month'"], + 'order_by' => ['event_date DESC'] + ] + ); + + return $aReturn; + } + + public static function getHistoryByUserId(array $aArgs = []) + { + ValidatorModel::notEmpty($aArgs, ['userId']); + ValidatorModel::stringType($aArgs, ['userId']); + + $aReturn = DatabaseModel::select( + [ + 'select' => empty($aArgs['select']) ? ['*'] : $aArgs['select'], + 'table' => ['history'], + 'where' => ['user_id = ?'], + 'data' => [$aArgs['userId']], + 'order_by' => ['event_date DESC'] + ] + ); + + return $aReturn; + } + + public static function getFilter(array $aArgs = []) + { + ValidatorModel::notEmpty($aArgs, ['select','event_date']); + ValidatorModel::stringType($aArgs, ['select']); + + $aReturn = DatabaseModel::select( + [ + 'select' => ['DISTINCT('.$aArgs['select'].')'], + 'table' => ['history'], + 'where' => ["event_date >= date '".$aArgs['event_date']."'","event_date < date '".$aArgs['event_date']."' + interval '1 month'"], + 'order_by' => [$aArgs['select'].' ASC'] + ] + ); + + return $aReturn; + } + + public static function getBatchFilter(array $aArgs = []) + { + ValidatorModel::notEmpty($aArgs, ['select','event_date']); + ValidatorModel::stringType($aArgs, ['select']); + + $aReturn = DatabaseModel::select( + [ + 'select' => ['DISTINCT('.$aArgs['select'].')'], + 'table' => ['history_batch'], + 'where' => ["event_date >= date '".$aArgs['event_date']."'","event_date < date '".$aArgs['event_date']."' + interval '1 month'"], + 'order_by' => [$aArgs['select'].' ASC'] + ] + ); + + return $aReturn; + } } diff --git a/core/Models/ServiceModelAbstract.php b/core/Models/ServiceModelAbstract.php index 59354d3cfde7149b51182b3db9f421ef988a7250..4808ce27811c5303b74ce22a0f870fd846c9ccbe 100755 --- a/core/Models/ServiceModelAbstract.php +++ b/core/Models/ServiceModelAbstract.php @@ -41,6 +41,7 @@ class ServiceModelAbstract return $applicationServices; } + public static function getApplicationAdministrationServicesByUserServices(array $aArgs = []) { ValidatorModel::notEmpty($aArgs, ['userServices']); @@ -145,6 +146,138 @@ class ServiceModelAbstract return $modulesServices; } + public static function getApplicationAdministrationMenuByXML() + { + $customId = CoreConfigModel::getCustomId(); + + if (file_exists("custom/{$customId}/apps/maarch_entreprise/xml/menu.xml")) { + $path = "custom/{$customId}/apps/maarch_entreprise/xml/menu.xml"; + } else { + $path = 'apps/maarch_entreprise/xml/menu.xml'; + } + + $modulesServices = []; + + $xmlfile = simplexml_load_file($path); + foreach ($xmlfile->MENU as $value) { + + $label = defined((string)$value->libconst) ? constant((string)$value->libconst) : (string)$value->libconst; + + $modulesServices['menuList'][] = [ + 'id' => (string) $value->id, + 'label' => $label, + 'link' => (string) $value->url, + 'icon' => (string)$value->style, + 'angular' => empty((string)$value->angular) ? 'false' : (string)$value->angular + ]; + + } + if (file_exists("custom/{$customId}/apps/maarch_entreprise/xml/config.xml")) { + $path = "custom/{$customId}/apps/maarch_entreprise/xml/config.xml"; + } else { + $path = 'apps/maarch_entreprise/xml/config.xml'; + } + $xmlfile = simplexml_load_file($path); + $modulesServices['applicationName'] = $xmlfile->CONFIG->applicationname; + foreach ($xmlfile->MODULES as $mod) { + $path = false; + $module = (string)$mod->moduleid; + + if (file_exists("custom/{$customId}/modules/{$module}/xml/menu.xml")) { + $path = "custom/{$customId}/modules/{$module}/xml/menu.xml"; + } else if (file_exists("modules/{$module}/xml/menu.xml")) { + $path = "modules/{$module}/xml/menu.xml"; + } + if ($path) { + $xmlfile = simplexml_load_file($path); + foreach ($xmlfile->MENU as $value) { + $id = (string) $value->id; + + $label = defined((string)$value->libconst) ? constant((string)$value->libconst) : (string)$value->libconst; + + $modulesServices['menuList'][] = [ + 'id' => (string) $value->id, + 'label' => $label, + 'link' => (string) $value->url, + 'icon' => (string)$value->style, + 'angular' => empty((string)$value->angular) ? 'false' : (string)$value->angular + ]; + + } + } + } + return $modulesServices; + } + + public static function getApplicationAdministrationMenuByUserServices(array $aArgs = []) + { + ValidatorModel::notEmpty($aArgs, ['userServices']); + ValidatorModel::arrayType($aArgs, ['userServices']); + + $customId = CoreConfigModel::getCustomId(); + + if (file_exists("custom/{$customId}/apps/maarch_entreprise/xml/menu.xml")) { + $path = "custom/{$customId}/apps/maarch_entreprise/xml/menu.xml"; + } else { + $path = 'apps/maarch_entreprise/xml/menu.xml'; + } + + $modulesServices = []; + + $xmlfile = simplexml_load_file($path); + foreach ($xmlfile->MENU as $value) { + if (in_array((string) $value->id, $aArgs['userServices'])) { + + $label = defined((string)$value->libconst) ? constant((string)$value->libconst) : (string)$value->libconst; + + $modulesServices['menuList'][] = [ + 'id' => (string) $value->id, + 'label' => $label, + 'link' => (string) $value->url, + 'icon' => (string)$value->style, + 'angular' => empty((string)$value->angular) ? 'false' : (string)$value->angular + ]; + } + } + if (file_exists("custom/{$customId}/apps/maarch_entreprise/xml/config.xml")) { + $path = "custom/{$customId}/apps/maarch_entreprise/xml/config.xml"; + } else { + $path = 'apps/maarch_entreprise/xml/config.xml'; + } + $xmlfile = simplexml_load_file($path); + $modulesServices['applicationName'] = $xmlfile->CONFIG->applicationname; + foreach ($xmlfile->MODULES as $mod) { + $path = false; + $module = (string)$mod->moduleid; + + if (file_exists("custom/{$customId}/modules/{$module}/xml/menu.xml")) { + $path = "custom/{$customId}/modules/{$module}/xml/menu.xml"; + } else if (file_exists("modules/{$module}/xml/menu.xml")) { + $path = "modules/{$module}/xml/menu.xml"; + } + if ($path) { + $xmlfile = simplexml_load_file($path); + foreach ($xmlfile->MENU as $value) { + $id = (string) $value->id; + + if (in_array((string) $value->id, $aArgs['userServices'])) { + + $label = defined((string)$value->libconst) ? constant((string)$value->libconst) : (string)$value->libconst; + + $modulesServices['menuList'][] = [ + 'id' => (string) $value->id, + 'label' => $label, + 'link' => (string) $value->url, + 'icon' => (string)$value->style, + 'angular' => empty((string)$value->angular) ? 'false' : (string)$value->angular + ]; + } + } + } + } + return $modulesServices; + } + public static function getAdministrationServicesByUserId(array $aArgs = []) { ValidatorModel::notEmpty($aArgs, ['userId']); @@ -157,6 +290,7 @@ class ServiceModelAbstract } $administration = []; + $administration['menu'] = ServiceModel::getApplicationAdministrationMenuByUserServices(['userServices' => $servicesStoredInDB]); $administration['application'] = ServiceModel::getApplicationAdministrationServicesByUserServices(['userServices' => $servicesStoredInDB]); $administration['modules'] = ServiceModel::getModulesAdministrationServicesByUserServices(['userServices' => $servicesStoredInDB]); diff --git a/core/Models/UserModelAbstract.php b/core/Models/UserModelAbstract.php index 65be101c1c8ea335cdbb268662e7fffb5fb4c4f9..2c7c25d5eccd482a76f3ecdedb2441c43fd444a0 100755 --- a/core/Models/UserModelAbstract.php +++ b/core/Models/UserModelAbstract.php @@ -484,9 +484,9 @@ class UserModelAbstract ValidatorModel::stringType($aArgs, ['userId']); $aGroups = DatabaseModel::select([ - 'select' => ['usergroup_content.group_id', 'usergroups.group_desc', 'usergroup_content.primary_group', 'usergroup_content.role'], - 'table' => ['usergroup_content, usergroups'], - 'where' => ['usergroup_content.group_id = usergroups.group_id', 'usergroup_content.user_id = ?'], + 'select' => ['usergroup_content.group_id', 'usergroups.group_desc', 'usergroup_content.primary_group', 'usergroup_content.role', 'security.maarch_comment'], + 'table' => ['usergroup_content, usergroups, security'], + 'where' => ['usergroup_content.group_id = usergroups.group_id', 'usergroup_content.user_id = ?','usergroups.group_id = security.group_id'], 'data' => [$aArgs['userId']] ]); @@ -541,7 +541,7 @@ class UserModelAbstract return true; } - public static function deactivateAbsenceById(array $aArgs = []) + public static function desactivateAbsenceById(array $aArgs = []) { ValidatorModel::notEmpty($aArgs, ['id']); ValidatorModel::intVal($aArgs, ['id']); diff --git a/core/Test/ResControllerTest.php b/core/Test/ResControllerTest.php index f9cc616d6b69972577cea81a4b1ae8a4f9b9de2b..6ed1101d217785d738725e2085b8ac0d5a2a85d0 100755 --- a/core/Test/ResControllerTest.php +++ b/core/Test/ResControllerTest.php @@ -227,7 +227,7 @@ class ResControllerTest extends TestCase $response = new \Slim\Http\Response(); $response = $action->create($request, $response, $aArgs); //print_r($response);exit; - $this->assertGreaterThan(1, json_decode($response->getBody())[0]); + $this->assertGreaterThan(1, json_decode($response->getBody())->resId); } public function testDeleteRes() diff --git a/core/Test/ResExtControllerTest.php b/core/Test/ResExtControllerTest.php index 51a8866bf9b5a87f7a2e63df1679831938e38256..36b3c4b8d4a9af4c8991a5b436bb64144101d66d 100755 --- a/core/Test/ResExtControllerTest.php +++ b/core/Test/ResExtControllerTest.php @@ -110,7 +110,7 @@ class ResExtControllerTest extends TestCase $response = new \Slim\Http\Response(); $response = $action->create($request, $response, $aArgs); - $this->assertTrue(json_decode($response->getBody())[0]); + $this->assertTrue(json_decode($response->getBody())->status); $this->deleteResArtefact($resId); } diff --git a/core/Test/StatusControllerTest.php b/core/Test/StatusControllerTest.php index 236b9fab859feb3de26bdeeed3376a9a824f596a..3171f4df1573c38df0e8248e664c8afc27f4e8e2 100755 --- a/core/Test/StatusControllerTest.php +++ b/core/Test/StatusControllerTest.php @@ -96,7 +96,7 @@ class StatusControllerTest extends TestCase $this->assertInternalType("int", $value->identifier); } - $this->assertNotNull($responseBody->lang); + //$this->assertNotNull($responseBody->lang); $elem = $responseBody->statusList; end($elem); @@ -185,7 +185,8 @@ class StatusControllerTest extends TestCase $response = $status->delete($request, new \Slim\Http\Response(), ['identifier'=> $lastIdentifier]); - $this->assertSame((string)$response->getBody(), '[true]'); + //$this->assertSame((string)$response->getBody(), '[true]'); + $this->assertRegexp('/statuses/', (string)$response->getBody()); } public function testGetNewInformations() @@ -199,6 +200,6 @@ class StatusControllerTest extends TestCase $responseBody = json_decode((string)$response->getBody()); $this->assertNotNull($responseBody->statusImages); - $this->assertNotNull($responseBody->lang); + //$this->assertNotNull($responseBody->lang); } } diff --git a/core/class/class_db_pdo.php b/core/class/class_db_pdo.php index cd56d9441cc38d706f41be8a68289e336b360e1a..5208171c977f0a0f6f0e081e06ddacadd8d4f85d 100755 --- a/core/class/class_db_pdo.php +++ b/core/class/class_db_pdo.php @@ -431,14 +431,23 @@ class Database extends functions ' ' . $limit_clause; if ($_SESSION['config']['databasetype'] == 'ORACLE') { - $query = 'SELECT' . + /*$query = 'SELECT' . ' ' . $select_opts . ' ' . $select_expr . ' FROM ' . $table_refs . ' WHERE ' . $where_def . ' ' . $other_clauses . ' ' . $limit_clause . - ' ' . $order_by; + ' ' . $order_by;*/ + $query = 'SELECT * FROM (SELECT' . + ' ' . $select_opts . + ' ' . $select_expr . + ' FROM ' . $table_refs . + ' WHERE ' . $where_def . + ' ' . $other_clauses . + // ' ' . $limit_clause . + ' ' . $order_by . + ') WHERE ' . $limit_clause; } else { $query = 'SELECT' . ' ' . $select_opts . diff --git a/core/class/docservers_controler.php b/core/class/docservers_controler.php index 489d19a23327b5a222be1f64d5951f77708e8dbc..7cb9b491ff3f0a84f72dd04e01d49e0c7b85ee3a 100755 --- a/core/class/docservers_controler.php +++ b/core/class/docservers_controler.php @@ -1539,7 +1539,8 @@ class docservers_controler $docserverTypeObject = $docserverTypeControler->get( $docserverObject->docserver_type_id ); - if (!file_exists($file)) { + if (!file_exists($file) || empty($adr[0][$cptDocserver]['path']) || empty($adr[0][$cptDocserver]['filename'])) { + $concatError .= _FILE_NOT_EXISTS_ON_THE_SERVER . ' : ' . $file . '||'; $history->add( diff --git a/core/manage_action.php b/core/manage_action.php index af48fa8dc9b9dfc5ad34040edf61490cc379f3ad..f636022f0a563f5f36dc032a2faf8603b5e5872b 100755 --- a/core/manage_action.php +++ b/core/manage_action.php @@ -141,7 +141,7 @@ if($_POST['req'] == 'valid_form' && !empty($_POST['action_id']) && isset($_POST[ } } elseif(trim($_POST['req']) == 'change_status' && !empty($_POST['values']) && !empty($_POST['new_status']) && !empty($_POST['table'])){ - $stmt = $db->query("select id from status where id = ?", array($_POST['new_status'])); + $stmt = $db->query("select id, label_status from status where id = ?", array($_POST['new_status'])); $lineStatus = $stmt->fetchObject(); if ($lineStatus->id <> '') { $arr_id = explode(',', $_POST['values']); @@ -163,6 +163,12 @@ elseif(trim($_POST['req']) == 'change_status' && !empty($_POST['values']) && !em echo "{status : 1, error_txt : '".addslashes(_ERROR_WITH_STATUS." ".functions::xssafe($query_str))."'}"; exit(); } + require_once("core".DIRECTORY_SEPARATOR."class".DIRECTORY_SEPARATOR."class_history.php"); + $hist = new history(); + $hist->add( + $_POST['table'], + $arr_id[$i], 'ACTION#', 'resadd', + _DOC_CREATED_WITH_STATUS . ' : '. $lineStatus->label_status, $_SESSION['config']['databasetype'], 'apps'); } } echo json_encode(['status' => 0, 'error_txt' => _STATUS_UPDATED.' : '.functions::xssafe($_POST['new_status']) ]); @@ -435,6 +441,9 @@ else if(empty($_POST['values']) || !isset($_POST['action_id']) || empty($_POST[' } $_SESSION['info'] = $what . ' '; $_SESSION['cpt_info_basket'] = 0; + if($_POST['module'] == 'null'){ + $_POST['module'] = ''; + } $hist->add( $_POST['table'], $arr_res[$i],'ACTION#'.$id_action, $id_action, diff --git a/install/class/Class_Install.php b/install/class/Class_Install.php index 15705c123e27b1e9e4609f6e8e7e513893405add..73240400528ec17035c52f02ac4b4ca605318444 100755 --- a/install/class/Class_Install.php +++ b/install/class/Class_Install.php @@ -2147,7 +2147,8 @@ class Install extends functions $db = new Database(); $query = "UPDATE users SET password=? WHERE user_id='superadmin'"; - $db->query($query, [\Core\Models\SecurityModel::getPasswordHash($newPass)]); + $sec = new security(); + $db->query($query, [$sec->getPasswordHash($newPass)]); } function copy_dir($dir2copy, $dir_paste, $excludeExt=false) diff --git a/install/scripts/password.php b/install/scripts/password.php index 8fd6e535c6c37fe39ac8692d020d9d11175269f2..22e55f606bae3b025407f9cce0d838f735156b4d 100755 --- a/install/scripts/password.php +++ b/install/scripts/password.php @@ -32,14 +32,14 @@ include_once '../../core/init.php'; require_once('install/class/Class_Install.php'); $Class_Install = new Install; - //CONTROLLER - if (!isset($_REQUEST['newSuperadminPass']) || empty($_REQUEST['newSuperadminPass'])) { + $trimmedPassword=rtrim($_REQUEST['newSuperadminPass']); + if (!isset($_REQUEST['newSuperadminPass']) || empty($trimmedPassword)) { header("Location: ../error.php?error=badForm"); exit; } - - $Class_Install->setSuperadminPass( + $resp=$Class_Install->setSuperadminPass( $_REQUEST['newSuperadminPass'] ); + - header("Location: ../index.php?step=resume"); + header("Location: ../index.php?step=config"); \ No newline at end of file diff --git a/install/view/password_view.php b/install/view/password_view.php index 86b6c7aa43235674b415256c408141c571dd8b1b..04be8f89a1a2bc8d4793ebc37d89b51651fd4818 100755 --- a/install/view/password_view.php +++ b/install/view/password_view.php @@ -74,7 +74,7 @@ <h6> <?php echo _PASSWORD_EXP;?> </h6> - <form action="scripts/password.php" method="post"> + <form action="scripts/password.php" method="post" id="newAdminPassForm" name="newAdminPassForm"> <table> <tr> <td> @@ -120,7 +120,7 @@ </a> </div> <div style="float: right;" class="nextButton" id="next"> - <a href="#" onClick="goTo('index.php?step=config');" id="okAdminPass" style="display: none;"> + <a href="#" onClick="document.getElementById('newAdminPassForm').submit();" id="okAdminPass" style="display: none;"> <?php echo _NEXT_INSTALL;?> </a> </div> diff --git a/modules/attachments/view_attachment.php b/modules/attachments/view_attachment.php index 937f9fab28cb887d1e67c9888ec17c31aa3ed0d8..bd5d3bb799fc49b3b1b2fb1d518ccc550ec7fafc 100755 --- a/modules/attachments/view_attachment.php +++ b/modules/attachments/view_attachment.php @@ -92,7 +92,7 @@ if (! empty($_SESSION['error'])) { $_SESSION['collection_id_choice'], $resIdMaster ); - $table = $sec->retrieve_table_from_coll($collId); + $table = $sec->retrieve_view_from_coll_id($collId); $stmt = $db->query( "SELECT res_id FROM " . $table . " WHERE res_id = ? ".$where2,array($resIdMaster)); diff --git a/modules/avis/send_docs_to_recommendation.php b/modules/avis/send_docs_to_recommendation.php index 86f07e35a7508b3418c3af8a33e39015850dc0c0..98b82f03c6113a2a41f16b480f95233d4299cb49 100755 --- a/modules/avis/send_docs_to_recommendation.php +++ b/modules/avis/send_docs_to_recommendation.php @@ -132,12 +132,12 @@ function get_form_txt($values, $path_manage_action, $id_action, $table, $module } } - $frm_str .='<b>'._RECOMMENDATION_LIMIT_DATE.':</b><br/>'; + $frm_str .='<b>'._RECOMMENDATION_LIMIT_DATE.' <span class="red_asterisk"><i class="fa fa-star"></i></span> :</b> <br/>'; $frm_str .= '<input name="recommendation_limit_date_tr" type="text" ' . 'id="recommendation_limit_date_tr" value="" placeholder="JJ-MM-AAAA" onfocus="checkRealDateAvis();" onChange="checkRealDateAvis();" onclick="clear_error(\'frm_error_' . $actionId . '\');showCalender(this);" onblur="document.getElementById(\'recommendation_limit_date\').value=document.getElementById(\'recommendation_limit_date_tr\').value;"/>'; $frm_str .='<br/>'; - $frm_str .='<br/><b>'._RECOMMENDATION_NOTE.':</b><br/>'; + $frm_str .='<br/><b>'._RECOMMENDATION_NOTE.' :</b><br/>'; $frm_str .= '<select name="templateNotes" id="templateNotes" style="width:98%;margin-bottom: 10px;background-color: White;border: 1px solid #999;color: #666;text-align: left;" ' . 'onchange="addTemplateToNote($(\'templateNotes\').value, \'' . $_SESSION['config']['businessappurl'] . 'index.php?display=true' @@ -195,6 +195,15 @@ function get_form_txt($values, $path_manage_action, $id_action, $table, $module $_SESSION['action_error'] = _NOTE. " " . _MANDATORY; return false; } + + $d = DateTime::createFromFormat('d-m-Y', $recommendation_limit_date); + + if ($d && $d->format('d-m-Y') === $recommendation_limit_date) { + } else { + $_SESSION['action_error'] = _RECOMMENDATION_LIMIT_DATE. " " . _WRONG_FORMAT; + return false; + } + return true; } diff --git a/modules/basket/Models/BasketsModelAbstract.php b/modules/basket/Models/BasketsModelAbstract.php index 1c05a64bca7f322ee48da73d2ef6a26b88e857a9..7d1f2edc4d189505c1d15a9b2eb01455dfea817e 100755 --- a/modules/basket/Models/BasketsModelAbstract.php +++ b/modules/basket/Models/BasketsModelAbstract.php @@ -103,6 +103,7 @@ class BasketsModelAbstract $aBaskets = DatabaseModel::select([ 'select' => ['groupbasket.basket_id', 'group_id', 'basket_name', 'basket_desc'], 'table' => ['groupbasket, baskets'], + 'debug' => ['true'], 'where' => ['group_id in (?)', 'groupbasket.basket_id = baskets.basket_id'], 'data' => [$groupIds], 'order_by' => ['group_id, basket_order, basket_name'] @@ -111,6 +112,14 @@ class BasketsModelAbstract foreach ($aBaskets as $key => $value) { $aBaskets[$key]['is_virtual'] = 'N'; $aBaskets[$key]['basket_owner'] = $aArgs['userId']; + $aBaskets2 = DatabaseModel::select([ + 'select' => ['new_user'], + 'table' => ['user_abs'], + 'where' => ['user_abs = ?', 'basket_id = ?'], + 'data' => [$aArgs['userId'],$value['basket_id']], + ]); + $aBaskets[$key]['userToDisplay'] = UserModel::getLabelledUserById(['userId' => $aBaskets2[0]['new_user']]); + $aBaskets[$key]['enabled'] = true; } $aBaskets = array_merge($aBaskets, BasketsModel::getAbsBasketsByUserId(['userId' => $aArgs['userId']])); } diff --git a/modules/basket/class/class_modules_tools_Abstract.php b/modules/basket/class/class_modules_tools_Abstract.php index e4d871ee32b3e7d1e5cd91c91f80e927c8b2e28c..078743e28ca85022866acf2bd33eb90447e3db25 100755 --- a/modules/basket/class/class_modules_tools_Abstract.php +++ b/modules/basket/class/class_modules_tools_Abstract.php @@ -679,7 +679,6 @@ abstract class basket_Abstract extends Database strtoupper($mode) == 'PAGE_USE' && $_SESSION['current_basket']['actions'][$i]['PAGE_USE'] == 'Y' && $testWhere && strtoupper($resId) != 'NONE' - && ($_SESSION['current_basket']['actions'][$i]['id'] <> 'IndexingBasket') ) { $where = ' where res_id = ' . $resId; if (!empty($_SESSION['current_basket']['actions'][$i]['WHERE'])) { @@ -689,7 +688,7 @@ abstract class basket_Abstract extends Database if ($stmt->rowCount() > 0) { $arr[] = ['VALUE' => $_SESSION['current_basket']['actions'][$i]['ID'], 'LABEL' => $_SESSION['current_basket']['actions'][$i]['LABEL']]; } - } else if (strtoupper($mode) == 'PAGE_USE' && $_SESSION['current_basket']['actions'][$i]['PAGE_USE'] == 'Y' && !$testWhere) { + } else if (strtoupper($mode) == 'PAGE_USE' && $_SESSION['current_basket']['actions'][$i]['PAGE_USE'] == 'Y') { $arr[] = ['VALUE' => $_SESSION['current_basket']['actions'][$i]['ID'], 'LABEL' => $_SESSION['current_basket']['actions'][$i]['LABEL']]; } else if (strtoupper($mode) == 'MASS_USE' && $_SESSION['current_basket']['actions'][$i]['MASS_USE'] == 'Y') { // If "MASS_USE" adding the actions in the array diff --git a/modules/content_management/dist/DisCM.jar b/modules/content_management/dist/DisCM.jar deleted file mode 100755 index c00f00b7160be83dc8ccbe2c060041a0cbfe1170..0000000000000000000000000000000000000000 Binary files a/modules/content_management/dist/DisCM.jar and /dev/null differ diff --git a/modules/content_management/dist/lib/commons-logging-1.2.jar b/modules/content_management/dist/lib/commons-logging-1.2.jar index 1fa460f3a6bd63b919a1f6d5cc831714fdf175c4..f0776f6f44b920c8511fe1922d36cdb02e517b27 100755 Binary files a/modules/content_management/dist/lib/commons-logging-1.2.jar and b/modules/content_management/dist/lib/commons-logging-1.2.jar differ diff --git a/modules/content_management/dist/lib/httpclient-4.5.2.jar b/modules/content_management/dist/lib/httpclient-4.5.2.jar index d08f4dbc92f1bf45dd04e876228d31a3118e464c..8cc0a013a46e3962bc21b4ea8d70b32dcfb6a4cd 100755 Binary files a/modules/content_management/dist/lib/httpclient-4.5.2.jar and b/modules/content_management/dist/lib/httpclient-4.5.2.jar differ diff --git a/modules/content_management/dist/lib/httpclient-cache-4.5.2.jar b/modules/content_management/dist/lib/httpclient-cache-4.5.2.jar index d3c0d2d92da69bd20aef7fb0eadf386189da7c1e..a570b724ee456345e707063c915994d0c3ab7625 100755 Binary files a/modules/content_management/dist/lib/httpclient-cache-4.5.2.jar and b/modules/content_management/dist/lib/httpclient-cache-4.5.2.jar differ diff --git a/modules/content_management/dist/lib/httpclient-win-4.5.2.jar b/modules/content_management/dist/lib/httpclient-win-4.5.2.jar index 065f01e509a1b861813d1300141e80c7be765a99..e0459fad426482ecdd3436cd99c87eac039e84b2 100755 Binary files a/modules/content_management/dist/lib/httpclient-win-4.5.2.jar and b/modules/content_management/dist/lib/httpclient-win-4.5.2.jar differ diff --git a/modules/content_management/dist/lib/httpcore-4.4.4.jar b/modules/content_management/dist/lib/httpcore-4.4.4.jar index 022dab7456cd0ac9fc48a8ece47aa5d149068a85..cfb54f35dcd915585eb2942bbe7487bafb2cd0ac 100755 Binary files a/modules/content_management/dist/lib/httpcore-4.4.4.jar and b/modules/content_management/dist/lib/httpcore-4.4.4.jar differ diff --git a/modules/content_management/dist/lib/plugin.jar b/modules/content_management/dist/lib/plugin.jar index 504eb7e799ef2d9e743a7e00449f3467b8a78c4c..047d55b4821c8bca44d964317f7a1382ed598c35 100755 Binary files a/modules/content_management/dist/lib/plugin.jar and b/modules/content_management/dist/lib/plugin.jar differ diff --git a/modules/content_management/dist/maarchCM.jar b/modules/content_management/dist/maarchCM.jar index 506116032c1743315a17f4104bd590226c9c763e..953b1c4713b6b8f9a2de1186619da413523e1d3f 100755 Binary files a/modules/content_management/dist/maarchCM.jar and b/modules/content_management/dist/maarchCM.jar differ diff --git a/modules/content_management/dist/maarchCM_sans_signature.jar b/modules/content_management/dist/maarchCM_sans_signature.jar deleted file mode 100755 index 7b0a215f47657450035179a077ccf9dfc6870110..0000000000000000000000000000000000000000 Binary files a/modules/content_management/dist/maarchCM_sans_signature.jar and /dev/null differ diff --git a/modules/content_management/dist/not_signed/lib/commons-logging-1.2.jar b/modules/content_management/dist/not_signed/lib/commons-logging-1.2.jar new file mode 100644 index 0000000000000000000000000000000000000000..1fa460f3a6bd63b919a1f6d5cc831714fdf175c4 Binary files /dev/null and b/modules/content_management/dist/not_signed/lib/commons-logging-1.2.jar differ diff --git a/modules/content_management/dist/not_signed/lib/httpclient-4.5.2.jar b/modules/content_management/dist/not_signed/lib/httpclient-4.5.2.jar new file mode 100644 index 0000000000000000000000000000000000000000..d08f4dbc92f1bf45dd04e876228d31a3118e464c Binary files /dev/null and b/modules/content_management/dist/not_signed/lib/httpclient-4.5.2.jar differ diff --git a/modules/content_management/dist/not_signed/lib/httpclient-cache-4.5.2.jar b/modules/content_management/dist/not_signed/lib/httpclient-cache-4.5.2.jar new file mode 100644 index 0000000000000000000000000000000000000000..d3c0d2d92da69bd20aef7fb0eadf386189da7c1e Binary files /dev/null and b/modules/content_management/dist/not_signed/lib/httpclient-cache-4.5.2.jar differ diff --git a/modules/content_management/dist/not_signed/lib/httpclient-win-4.5.2.jar b/modules/content_management/dist/not_signed/lib/httpclient-win-4.5.2.jar new file mode 100644 index 0000000000000000000000000000000000000000..065f01e509a1b861813d1300141e80c7be765a99 Binary files /dev/null and b/modules/content_management/dist/not_signed/lib/httpclient-win-4.5.2.jar differ diff --git a/modules/content_management/dist/not_signed/lib/httpcore-4.4.4.jar b/modules/content_management/dist/not_signed/lib/httpcore-4.4.4.jar new file mode 100644 index 0000000000000000000000000000000000000000..022dab7456cd0ac9fc48a8ece47aa5d149068a85 Binary files /dev/null and b/modules/content_management/dist/not_signed/lib/httpcore-4.4.4.jar differ diff --git a/modules/content_management/dist/not_signed/lib/plugin.jar b/modules/content_management/dist/not_signed/lib/plugin.jar new file mode 100644 index 0000000000000000000000000000000000000000..280df7212897d44db75d844f52e2e5019771ce61 Binary files /dev/null and b/modules/content_management/dist/not_signed/lib/plugin.jar differ diff --git a/modules/content_management/dist/DisCM_sans_signature.jar b/modules/content_management/dist/not_signed/maarchCM.jar old mode 100755 new mode 100644 similarity index 88% rename from modules/content_management/dist/DisCM_sans_signature.jar rename to modules/content_management/dist/not_signed/maarchCM.jar index 420bfb620f0b69d0b7aad211d0a6e7cc1909597d..8f864e0297724367de89501e6e16561eb33cbb41 Binary files a/modules/content_management/dist/DisCM_sans_signature.jar and b/modules/content_management/dist/not_signed/maarchCM.jar differ diff --git a/modules/content_management/dist/src/FileManager.java b/modules/content_management/dist/src/FileManager.java index 3b7eebddca7fd3280da9ca3594cd6748e01f03cb..aa2d592950e75b96023cc0acb55fa66cc95b7b1e 100755 --- a/modules/content_management/dist/src/FileManager.java +++ b/modules/content_management/dist/src/FileManager.java @@ -129,7 +129,7 @@ public class FileManager { AccessController.doPrivileged(new PrivilegedExceptionAction() { public Object run() throws IOException { if ("win".equals(os)) { - if (fileToLaunch.contains(".odt") || fileToLaunch.contains(".ods")) { + if ((fileToLaunch.contains(".odt") || fileToLaunch.contains(".ods")) || ("".equals(pathToFileToLaunch))) { //out.write("start /WAIT SOFFICE.exe -env:UserInstallation=file:///" // + pathToFileToLaunch.replace("\\", "/") + " \"" + pathToFileToLaunch + fileToLaunch + "\""); out.write("start /WAIT SOFFICE.exe \"-env:UserInstallation=file:///" + pathToFileToLaunch.replace("\\", "/") + idApplet +"/\" \"" + pathToFileToLaunch + fileToLaunch + "\""); @@ -139,7 +139,8 @@ public class FileManager { } else if ("mac".equals(os)) { out.write("open -W " + pathToFileToLaunch + fileToLaunch); } else if ("linux".equals(os)) { - out.write("libreoffice -env:UserInstallation=file://" + pathToFileToLaunch + idApplet +"/ " + pathToFileToLaunch + fileToLaunch + " || ooffice " + pathToFileToLaunch + fileToLaunch +"& wait"); + //out.write("libreoffice -env:UserInstallation=file://" + pathToFileToLaunch + idApplet +"/ " + pathToFileToLaunch + fileToLaunch + " || ooffice " + pathToFileToLaunch + fileToLaunch +"&wait"); + out.write("libreoffice -env:UserInstallation=file://" + pathToFileToLaunch + idApplet +"/ " + pathToFileToLaunch + fileToLaunch + "&wait"); } out.close(); File file = new File(pathToBatFile); @@ -275,6 +276,28 @@ public class FileManager { WinRegistry.HKEY_LOCAL_MACHINE, //HKEY "SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\App Paths\\" + program, //Key ""); + + if (path != null && !"soffice.exe".equals(program.toLowerCase())) { + int index; + String olderVersion = null; + boolean isOlderOffice = false; + + for (index = 7; index <= 12; ++index) + { + olderVersion = WinRegistry.readString ( + WinRegistry.HKEY_LOCAL_MACHINE, //HKEY + "Software\\Microsoft\\Office\\"+index+".0\\Word", //Key + ""); + System.out.println("Older version of Office ? : " + olderVersion); + if(olderVersion != null){ + isOlderOffice = true; + } + } + if(isOlderOffice == true){ + path = null; + } + } + return "\"" + path + "\""; } diff --git a/modules/content_management/dist/src/MaarchCM.java b/modules/content_management/dist/src/MaarchCM.java index f92c1c0fef3c4bab137563352f221ebef8733fa7..24ef49333a1e68717f9d562396b63f3c9f2919e2 100755 --- a/modules/content_management/dist/src/MaarchCM.java +++ b/modules/content_management/dist/src/MaarchCM.java @@ -96,6 +96,8 @@ public class MaarchCM { public MyLogger logger; public FileManager fM; public String fileToEdit; + public String editMode; + public List<String> fileToDelete = new ArrayList<String>(); @@ -323,6 +325,7 @@ public class MaarchCM { public void createPDF(String docxFile, String directory, boolean isUnix) { try { + System.out.println("mode ! : "+editMode); boolean conversion = true; String cmd = ""; if (docxFile.contains(".odt") || docxFile.contains(".ods") || docxFile.contains(".ODT") || docxFile.contains(".ODS")) { @@ -339,8 +342,12 @@ public class MaarchCM { if (useExeConvert.equals("false")) { if (isUnix) { cmd = "libreoffice -env:UserInstallation=file://"+userLocalDirTmp+idApplet+"_conv\\ --headless --convert-to pdf --outdir \"" + userLocalDirTmp.substring(0, userLocalDirTmp.length() - 1) + "\" \"" + docxFile + "\""; - } else { - cmd = "cmd /C c:\\Windows\\System32\\cscript \"" + vbsPath + "\" \"" + docxFile + "\" /nologo \r\n"; + } else if(editMode.equals("libreoffice")){ + String convertProgram; + convertProgram = fM.findPathProgramInRegistry("soffice.exe"); + cmd = convertProgram + " \"-env:UserInstallation=file:///"+userLocalDirTmp.replace("\\", "/")+idApplet+"_conv/\" --headless --convert-to pdf --outdir \"" + userLocalDirTmp.substring(0, userLocalDirTmp.length() - 1) + "\" \"" + docxFile + "\" \r\n"; + }else{ + cmd = "cmd /C c:\\Windows\\System32\\cscript \"" + vbsPath + "\" \"" + docxFile + "\" /nologo \r\n"; } } else { @@ -481,7 +488,7 @@ public class MaarchCM { System.out.println("----------BEGIN EDIT OBJECT---------- LGI by Maarch and DIS 22/01/2017"); System.out.println("----------BEGIN LOCAL DIR TMP IF NOT EXISTS----------"); - String os = System.getProperty("os.name").toLowerCase(); + os = System.getProperty("os.name").toLowerCase(); boolean isUnix = os.contains("nix") || os.contains("nux"); boolean isWindows = os.contains("win"); boolean isMac = os.contains("mac"); @@ -728,24 +735,51 @@ public class MaarchCM { Process proc; logger.log("LAUNCH THE EDITOR !", Level.INFO); + if ("linux".equals(os) || "mac".equals(os)) { + editMode = "libreoffice"; proc = fM.launchApp(appPath); } else { logger.log("FILE TO EDIT : " + userLocalDirTmp + fileToEdit, Level.INFO); String programName; programName = fM.findGoodProgramWithExt(fileExtension); - logger.log("PROGRAM NAME TO EDIT : " + programName, Level.INFO); String pathProgram; pathProgram = fM.findPathProgramInRegistry(programName); - logger.log("PROGRAM PATH TO EDIT : " + pathProgram, Level.INFO); String options; - options = fM.findGoodOptionsToEdit(fileExtension); + System.out.println("check prog name : "+programName); + System.out.println("check path : "+pathProgram); + if("soffice.exe".equals(programName)){ + if("\"null\"".equals(pathProgram)){ + System.out.println(programName+" not found! switch to microsoft office..."); + programName = "office.exe"; + pathProgram = fM.findPathProgramInRegistry(programName); + options = fM.findGoodOptionsToEdit(fileExtension); + }else{ + options = "\"-env:UserInstallation=file:///" + userLocalDirTmp.replace("\\", "/") + idApplet +"/\" "; + } + }else{ + if("\"null\"".equals(pathProgram)){ + System.out.println(programName+" not found! switch to libreoffice..."); + programName = "soffice.exe"; + pathProgram = fM.findPathProgramInRegistry(programName); + options = "\"-env:UserInstallation=file:///" + userLocalDirTmp.replace("\\", "/") + idApplet +"/\" "; + }else{ + options = fM.findGoodOptionsToEdit(fileExtension); + } + } + + if("soffice.exe".equals(programName)){ + editMode = "libreoffice"; + }else{ + editMode = "office"; + } + logger.log("PROGRAM NAME TO EDIT : " + programName, Level.INFO); logger.log("OPTION PROGRAM TO EDIT " + options, Level.INFO); + logger.log("PROGRAM PATH TO EDIT : " + pathProgram, Level.INFO); + + String pathCommand; - if("".equals(options)){ - options = "\"-env:UserInstallation=file:///" + userLocalDirTmp.replace("\\", "/") + idApplet +"/\" "; - } pathCommand = pathProgram + " " + options + "\"" + userLocalDirTmp + fileToEdit + "\""; logger.log("PATH COMMAND TO EDIT " + pathCommand, Level.INFO); proc = fM.launchApp(pathCommand); diff --git a/modules/content_management/dist/srcDIS/DisCM.java b/modules/content_management/dist/srcDIS/DisCM.java deleted file mode 100755 index 337bccc2759768704e2d3761fa574708bef25b36..0000000000000000000000000000000000000000 --- a/modules/content_management/dist/srcDIS/DisCM.java +++ /dev/null @@ -1,899 +0,0 @@ -/** - * Jdk platform : 1.8 - */ - -/** - * SVN version 141 - */ - -package com.dis; - -//import java.applet.Applet; -import java.io.*; -import java.lang.reflect.InvocationTargetException; -import java.net.MalformedURLException; -import java.net.URL; -import java.nio.file.FileVisitResult; -import java.nio.file.Files; -import java.nio.file.Path; -import java.nio.file.Paths; -import java.nio.file.SimpleFileVisitor; -import java.nio.file.attribute.BasicFileAttributes; -import java.security.PrivilegedActionException; -import java.util.ArrayList; -import java.util.HashSet; -import java.util.Hashtable; -import java.util.Iterator; -import java.util.List; -import java.util.Set; -import java.util.logging.Level; -import java.util.logging.Logger; -//import javax.swing.JApplet; -import javax.xml.parsers.DocumentBuilder; -import javax.xml.parsers.DocumentBuilderFactory; -import javax.xml.parsers.ParserConfigurationException; - -import netscape.javascript.JSException; -import org.apache.http.client.config.CookieSpecs; -import org.apache.http.client.config.RequestConfig; -import org.apache.http.client.methods.CloseableHttpResponse; -import org.apache.http.client.methods.HttpPost; -import org.apache.http.client.protocol.HttpClientContext; -import org.apache.http.entity.AbstractHttpEntity; -import org.apache.http.impl.client.*; -import org.apache.http.impl.cookie.BasicClientCookie; -import org.w3c.dom.Document; -import org.w3c.dom.NodeList; -import org.xml.sax.SAXException; -import netscape.javascript.JSObject; - -import javax.swing.JOptionPane; -import org.apache.http.NameValuePair; -import org.apache.http.client.entity.UrlEncodedFormEntity; -import org.apache.http.message.BasicNameValuePair; - -/** - * DisCM class manages webservices between end user desktop and Maarch - * @author DIS - */ -//public class DisCM extends JApplet { -public class DisCM { - - //INIT PARAMETERS - protected String url; - protected String idApplet; - protected String objectType; - protected String objectTable; - protected String objectId; - protected String cookie; - protected String clientSideCookies; - protected String uniqueId; - protected String convertPdf; - protected String domain; - protected String userLocalDirTmp; - protected String userMaarch; - protected String messageStatus; - static Hashtable messageResult = new Hashtable(); - - //XML PARAMETERS - protected String status; - protected String appPath; - protected String appPath_convert; - protected String fileContent; - protected String fileContentVbs; - protected String vbsPath; - protected String fileContentExe; - protected String useExeConvert; - protected String fileExtension; - protected String error; - protected String endMessage; - protected String os; - protected String fileContentTosend; - protected String pdfContentTosend; - - private final HttpClientContext httpContext = HttpClientContext.create(); - private CloseableHttpClient httpClient; // Apache HttpClient yet to be instantiated - - public MyLogger logger; - public FileManager fM; - public String fileToEdit; - - public List<String> fileToDelete = new ArrayList<String>(); - - - public static void main(String[] args) throws JSException { - DisCM DisCM = new DisCM(); - DisCM.start(args); - } - - /** - * Launch of the JNLP - */ - public void start(String[] args) throws JSException { - - System.out.println("----------BEGIN----------"); - System.out.println("----------ARGUMENTS----------"); - - int index; - - for (index = 0; index < args.length; ++index) - { - System.out.println("args[" + index + "]: " + args[index]); - } - url = args[0]; - objectType = args[1]; - objectTable = args[2]; - objectId = args[3]; - uniqueId = args[4]; - cookie = args[5]; - clientSideCookies = args[6]; - idApplet = args[7]; - userMaarch = args[8]; - convertPdf = args[9]; - - System.out.println("URL : " + url); - System.out.println("OBJECT TYPE : " + objectType); - System.out.println("ID APPLET : " + idApplet); - System.out.println("OBJECT TABLE : " + objectTable); - System.out.println("OBJECT ID : " + objectId); - System.out.println("UNIQUE ID : " + uniqueId); - System.out.println("COOKIE : " + cookie); - System.out.println("CLIENTSIDECOOKIES : " + clientSideCookies); - System.out.println("USERMAARCH : " + userMaarch); - System.out.println("CONVERPDF : " + convertPdf); - System.out.println("----------CONTROL PARAMETERS----------"); - - if ( - isURLInvalid() || - isObjectTypeInvalid() || - isObjectTableInvalid() || - isObjectIdInvalid() || - isCookieInvalid() - ) { - System.out.println("PARAMETERS NOT OK ! END OF APPLICATION"); - //System.exit(0); - try { - //DisCM.getAppletContext().showDocument(new URL("error.html")); - //Go to an appropriate error page - } catch (Exception e) { - //Nothing - } - } - - System.out.println("----------END PARAMETERS----------"); - - if ("empty".equals(uniqueId)) { - uniqueId = null; - } - - if ("empty".equals(clientSideCookies)) { - clientSideCookies = null; - } - - // The following code is to ensure a high level of management for HTTP cookies - BasicCookieStore cookieStore = new BasicCookieStore(); - // Loading the cookie store with the Maarch cookie provided by the server - cookieStore.addCookie(getCookieFromString(cookie)); - if ( - clientSideCookies != null && - clientSideCookies.length() > 0 - ) { - System.out.println("clientSideCookies : " + clientSideCookies); - // Within the whole cookie string returned from JavaScript, cookies are separated by a semicolon followed by a space - // Let's get an array where cookies are stored with a "name=value" pattern - String[] cookies = clientSideCookies.split(";\\s"); - System.out.println("cookies : " + cookies); - // Iterate through the cookie array to retrieve each cookie name ans value and load the cookie store - for (String nameValue : cookies) { - cookieStore.addCookie(getCookieFromString(nameValue)); // Loading the cookie store - } - } - httpContext.setCookieStore(cookieStore); // Assign all the cookies retrieved from JavaScript - // Apply a Cookie policy: https://hc.apache.org/httpcomponents-client-ga/tutorial/html/statemgmt.html - RequestConfig globalConfig = RequestConfig.custom().setCookieSpec(CookieSpecs.DEFAULT).build(); - - // Pick up the best Apache HttpClient to do the job - // which will allows for the automatic retrieval of the user session Kerberos ticket, - // so this app will be able to properly talk with a proxy - if ("win".equals(os) && WinHttpClients.isWinAuthAvailable()) { - // Instantiation of the Apache HttpClient for Windows 7 - httpClient = WinHttpClients.custom().setDefaultRequestConfig(globalConfig).setDefaultCookieStore(cookieStore).build(); - System.out.println("The Apache HttpClient for Windows 7 was picked up"); - } else { - // Instantiation of the generic Apache HttpClient - HttpClientBuilder httpClientBuilder = HttpClients.custom(); - httpClientBuilder.useSystemProperties(); - httpClientBuilder.setDefaultRequestConfig(globalConfig); - httpClientBuilder.setDefaultCookieStore(cookieStore); - httpClient = httpClientBuilder.build(); - System.out.println("The generic Apache HttpClient was picked up"); - } - - if (httpClient == null) { - System.out.println("NO HTTP CLIENT WAS INSTANTIATED, THE APPLICATION WILL FAIL!"); - } - - try { - editObject(); - //TODO exit of JNLP - //DisCM.destroy(); - //DisCM.stop(); - System.exit(0); - } catch (Exception ex) { - Logger.getLogger(DisCM.class.getName()).log(Level.SEVERE, null, ex); - } - } - - /** - * Controls the url parameter - * @return boolean - */ - private boolean isURLInvalid() { - try { - URL address = new URL(url); // Trying to build a valid URL - address.openConnection().connect(); // Trying to open a valid connection - domain = address.getHost(); // Retrieve the domain used - System.out.println("DOMAIN USED IS: " + domain); - return false; //success - } catch (MalformedURLException e) { - System.out.println("the URL is not a valid form " + url); - } catch (IOException e) { - System.out.println("the connection couldn't be etablished " + url); - } - return true; //default is failure - } - - /** - * Controls the objectType parameter - * @return boolean - */ - private boolean isObjectTypeInvalid() { - Set<String> whiteList = new HashSet<>(); - whiteList.add("template"); - whiteList.add("templateStyle"); - whiteList.add("attachmentVersion"); - whiteList.add("attachmentUpVersion"); - whiteList.add("resource"); - whiteList.add("attachmentFromTemplate"); - whiteList.add("attachment"); - whiteList.add("outgoingMail"); - if (whiteList.contains(objectType)) return false; //success - System.out.println("ObjectType not in the authorized list " + objectType); - return true; //default is failure - } - - /** - * Controls the objectTable parameter - * @return boolean - */ - private boolean isObjectTableInvalid() { - Set<String> whiteList = new HashSet<>(); - whiteList.add("res_letterbox"); - whiteList.add("res_business"); - whiteList.add("res_x"); - whiteList.add("res_attachments"); - whiteList.add("mlb_coll_ext"); - whiteList.add("business_coll_ext"); - whiteList.add("res_version_letterbox"); - whiteList.add("res_version_business"); - whiteList.add("res_version_x"); - whiteList.add("res_view_attachments"); - whiteList.add("res_view"); - whiteList.add("res_view_letterbox"); - whiteList.add("res_view_business"); - whiteList.add("templates"); - if (whiteList.contains(objectTable)) return false; //success - System.out.println("objectTable not in the authorized list " + objectTable); - return true; //default is failure - } - - /** - * Controls the objectId parameter - * @return boolean - */ - private boolean isObjectIdInvalid() { - if (objectId != null && objectId.length() > 0) return false; //success - System.out.println("objectId is null or empty " + objectId); - return true; //default is failure - } - - /** - * Controls the cookie parameter - * @return boolean - */ - private boolean isCookieInvalid() { - if (cookie != null && cookie.length() > 0) return false; //success - System.out.println("cookie is null or empty " + cookie); - return true; //default is failure - } - - /** - * Build a cookie from a String - * @param nameValue - * @return BasicClientCookie - */ - private BasicClientCookie getCookieFromString(String nameValue) { - int separator = nameValue.indexOf('='); // Locating the equal character - String name = nameValue.substring(0, separator); // Getting everything before the equal character - String value = nameValue.substring(separator + 1); // Getting everything after the equal character - BasicClientCookie cookie = new BasicClientCookie(name, value); - cookie.setPath("/"); - cookie.setDomain(domain); - return cookie; - } - - public void createPDF(String docxFile, String directory, boolean isUnix) { - try { - boolean conversion = true; - String cmd = ""; - if (docxFile.contains(".odt") || docxFile.contains(".ods") || docxFile.contains(".ODT") || docxFile.contains(".ODS")) { - logger.log("This is opendocument ! ", Level.INFO); - if (isUnix) { - cmd = "libreoffice -env:UserInstallation=file://"+userLocalDirTmp+idApplet+"_conv/ --headless --convert-to pdf --outdir \"" + userLocalDirTmp.substring(0, userLocalDirTmp.length() - 1) + "\" \"" + docxFile + "\""; - } else { - String convertProgram; - convertProgram = fM.findPathProgramInRegistry("soffice.exe"); - cmd = convertProgram + " \"-env:UserInstallation=file:///"+userLocalDirTmp.replace("\\", "/")+idApplet+"_conv/\" --headless --convert-to pdf --outdir \"" + userLocalDirTmp.substring(0, userLocalDirTmp.length() - 1) + "\" \"" + docxFile + "\" \r\n"; - } - - } else if (docxFile.contains(".doc") || docxFile.contains(".docx") || docxFile.contains(".DOC") || docxFile.contains(".DOCX")) { - if (useExeConvert.equals("false")) { - if (isUnix) { - cmd = "libreoffice -env:UserInstallation=file://"+userLocalDirTmp+idApplet+"_conv\\ --headless --convert-to pdf --outdir \"" + userLocalDirTmp.substring(0, userLocalDirTmp.length() - 1) + "\" \"" + docxFile + "\""; - } else { - cmd = "cmd /C c:\\Windows\\System32\\cscript \"" + vbsPath + "\" \"" + docxFile + "\" /nologo \r\n"; - } - } else { - - StringBuffer buffer = new StringBuffer(docxFile); - buffer.replace(buffer.lastIndexOf("."), buffer.length(), ".pdf"); - String pdfOut = buffer.toString(); - - cmd = "cmd /C \"" + userLocalDirTmp + "Word2Pdf.exe\" \"" + docxFile + "\" \"" + pdfOut + "\" \r\n"; - } - } else { - conversion = false; - } - - if (conversion) { - logger.log("EXEC PATH : " + cmd, Level.INFO); - FileManager fM = new FileManager(); - - Process proc_vbs; - if (isUnix) { - //cmd = "cscript \""+vbsPath+"\" \""+docxFile+"\" /nologo \r\n"; - final Writer outBat; - outBat = new OutputStreamWriter(new FileOutputStream(appPath_convert), "CP850"); - logger.log("--- cmd sh --- " + cmd, Level.INFO); - outBat.write(cmd); - //outBat.write("exit \r\n"); - outBat.close(); - - File myFileBat = new File(appPath_convert); - myFileBat.setReadable(true, false); - myFileBat.setWritable(true, false); - myFileBat.setExecutable(true, false); - - /*String cmd2 = "start /WAIT /MIN "+appPath_convert+" \r\n"; - final Writer outBat2 = new OutputStreamWriter(new FileOutputStream(appPath), "CP850"); - outBat2.write(cmd2); - outBat2.write("exit \r\n"); - outBat2.close();*/ - - /*File myFileBat2 = new File(appPath); - myFileBat2.setReadable(true, false); - myFileBat2.setWritable(true, false); - myFileBat2.setExecutable(true, false);*/ - - final String exec_vbs = "\"" + appPath + "\""; - proc_vbs = fM.launchApp(appPath_convert); - } else { - proc_vbs = fM.launchApp(cmd); - } - proc_vbs.waitFor(); - } - - } catch (Throwable e) { - logger.log("Erreur ! : " + e, Level.SEVERE); - e.printStackTrace(); - } - } - - /** - * Retrieve the xml message from Maarch and parse it - * @param flux_xml xml content message - */ - public void parse_xml(InputStream flux_xml) throws SAXException, IOException, ParserConfigurationException { - logger.log("----------BEGIN PARSE XML----------", Level.INFO); - DocumentBuilder builder = DocumentBuilderFactory.newInstance().newDocumentBuilder(); - - try { - Document doc = builder.parse(flux_xml); - messageResult.clear(); - NodeList level_one_list = doc.getChildNodes(); - for (Integer i = 0; i < level_one_list.getLength(); i++) { - NodeList level_two_list = level_one_list.item(i).getChildNodes(); - if ("SUCCESS".equals(level_one_list.item(i).getNodeName())) { - for (Integer j = 0; j < level_one_list.item(i).getChildNodes().getLength(); j++) { - messageResult.put(level_two_list.item(j).getNodeName(), level_two_list.item(j).getTextContent()); - } - messageStatus = "SUCCESS"; - } else if ("ERROR".equals(level_one_list.item(i).getNodeName())) { - for (Integer j = 0; j < level_one_list.item(i).getChildNodes().getLength(); j++) { - messageResult.put(level_two_list.item(j).getNodeName(), level_two_list.item(j).getTextContent()); - } - messageStatus = "ERROR"; - } - } - } catch (SAXException | IOException e) { - - logger.log("ERREUR : Le document n'a pas pu être transféré du coté client. Assurez-vous que le modèle n'est pas corrompu et que la zone de stockage des templates soit correct.", Level.SEVERE); - messageStatus = "ERROR"; - messageResult.put("ERROR", "ERREUR : Le document n'a pas pu être transféré du coté client. Assurez-vous que le modèle n'est pas corrompu et que la zone de stockage des templates soit correct."); - JOptionPane.showMessageDialog(null, "ERREUR ! L'édition de votre document a échoué. Assurez-vous que le modèle n'est pas corrompu et que la zone de stockage des modèles soit correct."); - } - logger.log("----------END PARSE XML----------", Level.INFO); - } - - /** - * Manage the return of program execution - * @param result result of the program execution - */ - public void processReturn(Hashtable result) { - Iterator itValue = result.values().iterator(); - Iterator itKey = result.keySet().iterator(); - while (itValue.hasNext()) { - String value = (String) itValue.next(); - String key = (String) itKey.next(); - logger.log(key + " : " + value, Level.INFO); - if ("STATUS".equals(key)) status = value; - if ("OBJECT_TYPE".equals(key)) objectType = value; - if ("OBJECT_TABLE".equals(key)) objectTable = value; - if ("OBJECT_ID".equals(key)) objectId = value; - if ("UNIQUE_ID".equals(key)) uniqueId = value; - if ("COOKIE".equals(key)) cookie = value; - if ("CLIENTSIDECOOKIES".equals(key)) clientSideCookies = value; - if ("APP_PATH".equals(key)) ; //appPath = value; - if ("FILE_CONTENT".equals(key)) fileContent = value; - if ("FILE_CONTENT_VBS".equals(key)) fileContentVbs = value; - if ("VBS_PATH".equals(key)) vbsPath = value; - if ("FILE_CONTENT_EXE".equals(key)) fileContentExe = value; - if ("USE_EXE_CONVERT".equals(key)) useExeConvert = value; - if ("FILE_EXTENSION".equals(key)) fileExtension = value; - if ("ERROR".equals(key)) error = value; - if ("END_MESSAGE".equals(key)) endMessage = value; - } - //send message error to Maarch if necessary - if (!error.isEmpty()) { - //TODO exit of the JNLP - //destroy(); - //stop(); - System.exit(0); - } - } - - /** - * Main function of the class - * enables you to edit document with the user favorit editor - * @return nothing - * @throws java.lang.Exception - */ - public String editObject() throws Exception, InterruptedException, JSException { - - System.out.println("----------BEGIN EDIT OBJECT---------- LGI by DIS 22/01/2017"); - System.out.println("----------BEGIN LOCAL DIR TMP IF NOT EXISTS----------"); - String os = System.getProperty("os.name").toLowerCase(); - boolean isUnix = os.contains("nix") || os.contains("nux"); - boolean isWindows = os.contains("win"); - boolean isMac = os.contains("mac"); - userLocalDirTmp = System.getProperty("user.home"); - - fM = new FileManager(); - - if (isWindows) { - System.out.println("This is Windows"); - userLocalDirTmp = userLocalDirTmp + "\\maarchTmp\\"; - appPath = userLocalDirTmp + "start.bat"; - appPath_convert = userLocalDirTmp + "conversion_"+idApplet+".bat"; - os = "win"; - } else if (isMac) { - System.out.println("This is Mac"); - userLocalDirTmp = userLocalDirTmp + "/maarchTmp/"; - appPath = userLocalDirTmp + "start.sh"; - appPath_convert = userLocalDirTmp + "conversion_"+idApplet+".sh"; - os = "mac"; - } else if (isUnix) { - System.out.println("This is Unix or Linux"); - userLocalDirTmp = userLocalDirTmp + "/maarchTmp/"; - appPath = userLocalDirTmp + "start.sh"; - appPath_convert = userLocalDirTmp + "conversion_"+idApplet+".sh"; - os = "linux"; - } else { - System.out.println("Your OS is not supported!!"); - } - fileToDelete.add(appPath_convert); - - System.out.println("Create the logger"); - logger = new MyLogger(userLocalDirTmp); - - System.out.println("APP PATH: " + appPath); - System.out.println("----------BEGIN LOCAL DIR TMP IF NOT EXISTS----------"); - - String info = fM.createUserLocalDirTmp(userLocalDirTmp, os); - - if (info == "ERROR") { - logger.log("ERREUR : Permissions insuffisante sur votre répertoire temporaire maarch", Level.SEVERE); - messageStatus = "ERROR"; - messageResult.clear(); - messageResult.put("ERROR", "ERREUR : Permissions insuffisante sur votre répertoire temporaire maarch"); - JOptionPane.showMessageDialog(null, "ERREUR ! Permissions insuffisante sur votre répertoire temporaire maarch."); - processReturn(messageResult); - } - - System.out.println("Create the logger"); - logger = new MyLogger(userLocalDirTmp); - - /*logger.log("Delete thefile if exists", Level.INFO); - FileManager.deleteFilesOnDir(userLocalDirTmp, "thefile");*/ - - logger.log("----------PARAM ----------", Level.INFO); - logger.log("URL : " + url, Level.INFO); - logger.log("OBJECT TYPE : " + objectType, Level.INFO); - logger.log("ID APPLET : " + idApplet, Level.INFO); - logger.log("OBJECT TABLE : " + objectTable, Level.INFO); - logger.log("OBJECT ID : " + objectId, Level.INFO); - logger.log("UNIQUE ID : " + uniqueId, Level.INFO); - logger.log("COOKIE : " + cookie, Level.INFO); - logger.log("CLIENTSIDECOOKIES : " + clientSideCookies, Level.INFO); - logger.log("USERMAARCH : " + userMaarch, Level.INFO); - - logger.log("----------BEGIN OPEN REQUEST----------", Level.INFO); - String urlToSend = url + "?action=editObject&objectType=" + objectType - + "&objectTable=" + objectTable + "&objectId=" + objectId - + "&uniqueId=" + uniqueId; - sendHttpRequest(urlToSend, "none", false); - logger.log("MESSAGE STATUS : " + messageStatus, Level.INFO); - logger.log("MESSAGE RESULT : ", Level.INFO); - processReturn(messageResult); - logger.log("----------END OPEN REQUEST----------", Level.INFO); - - fileToEdit = "thefile_" + idApplet + "." + fileExtension; - - logger.log("----------BEGIN CREATE THE BAT TO LAUNCH IF NECESSARY----------", Level.INFO); - logger.log("create the file : " + appPath, Level.INFO); - fM.createBatFile( - appPath, - userLocalDirTmp, - fileToEdit, - os, - idApplet - ); - logger.log("----------END CREATE THE BAT TO LAUNCH IF NECESSARY----------", Level.INFO); - - if ("ok".equals(status)) { - logger.log("RESPONSE OK", Level.INFO); - - if ("true".equals(convertPdf)) { - logger.log("CREATE FILE IN LOCAL PATH", Level.INFO); - if (useExeConvert.equals("false")) { - logger.log("---------- VBS FILE ----------", Level.INFO); - logger.log(" Path = " + vbsPath, Level.INFO); - if (vbsPath.equals("")) vbsPath = userLocalDirTmp + "DOC2PDF_VBS.vbs"; - boolean isVbsExists = fM.isPsExecFileExists(vbsPath); - if (!isVbsExists) fM.createFile(fileContentVbs, vbsPath); - } else { - boolean isConvExecExists = fM.isPsExecFileExists(userLocalDirTmp + "Word2Pdf.exe"); - if (!isConvExecExists) fM.createFile(fileContentExe, userLocalDirTmp + "Word2Pdf.exe"); - } - } - - logger.log("----------BEGIN EXECUTION OF THE EDITOR----------", Level.INFO); - logger.log("CREATE FILE IN LOCAL PATH", Level.INFO); - fM.createFile(fileContent, userLocalDirTmp + fileToEdit); - fileToDelete.add(userLocalDirTmp + fileToEdit); - - Thread theThread; - theThread = new Thread(new ProcessLoop(this)); - - theThread.start(); - - String actualContent; - fileContentTosend = ""; - do { - theThread.sleep(3000); - File fileTotest = new File(userLocalDirTmp + fileToEdit); - if (fileTotest.canRead()) { - actualContent = FileManager.encodeFile(userLocalDirTmp + fileToEdit); - if (!fileContentTosend.equals(actualContent)) { - fileContentTosend = actualContent; - logger.log("----------[SECURITY BACKUP] BEGIN SEND OF THE OBJECT----------", Level.INFO); - String urlToSave = url + "?action=saveObject&objectType=" + objectType - + "&objectTable=" + objectTable + "&objectId=" + objectId - + "&uniqueId=" + uniqueId + "&step=backup&userMaarch=" + userMaarch; - logger.log("[SECURITY BACKUP] URL TO SAVE : " + urlToSave, Level.INFO); - sendHttpRequest(urlToSave, fileContentTosend, false); - logger.log("[SECURITY BACKUP] MESSAGE STATUS : " + messageStatus, Level.INFO); - } - } else { - logger.log(userLocalDirTmp + fileToEdit + " FILE NOT READABLE !!!!!!", Level.INFO); - } - } - while (theThread.isAlive()); - - theThread.interrupt(); - - logger.log("----------END EXECUTION OF THE EDITOR----------", Level.INFO); - - logger.log("----------BEGIN RETRIEVE CONTENT OF THE OBJECT----------", Level.INFO); - - fileContentTosend = FileManager.encodeFile(userLocalDirTmp + fileToEdit); - - logger.log("----------END RETRIEVE CONTENT OF THE OBJECT----------", Level.INFO); - - if ("true".equals(convertPdf)) { - if ((fileExtension.equalsIgnoreCase("docx") || fileExtension.equalsIgnoreCase("doc") || fileExtension.equalsIgnoreCase("docm") || fileExtension.equalsIgnoreCase("odt") || fileExtension.equalsIgnoreCase("ott"))) { - logger.log("----------CONVERSION PDF----------", Level.INFO); - createPDF(userLocalDirTmp + fileToEdit, userLocalDirTmp, isUnix); - - String pdfFile = userLocalDirTmp + "thefile_" + idApplet + ".pdf"; - - logger.log("----------BEGIN RETRIEVE CONTENT OF THE OBJECT----------", Level.INFO); - if (fM.isPsExecFileExists(pdfFile)) { - pdfContentTosend = FileManager.encodeFile(pdfFile); - fileToDelete.add(pdfFile); - } else { - pdfContentTosend = "null"; - logger.log("ERREUR DE CONVERSION PDF !", Level.WARNING); - JOptionPane.showMessageDialog(null, "Attention ! La conversion PDF a échoué mais le document a bien été transféré."); - } - logger.log("----------END RETRIEVE CONTENT OF THE OBJECT----------", Level.INFO); - - logger.log("---------- FIN CONVERSION PDF----------", Level.INFO); - }else{ - pdfContentTosend = "not allowed"; - logger.log("Conversion not allowed for this extension : " + fileExtension, Level.INFO); - } - } - - - String urlToSave = url + "?action=saveObject&objectType=" + objectType - + "&objectTable=" + objectTable + "&objectId=" + objectId - + "&uniqueId=" + uniqueId + "&idApplet=" + idApplet + "&step=end&userMaarch=" + userMaarch; - logger.log("----------BEGIN SEND OF THE OBJECT----------", Level.INFO); - logger.log("URL TO SAVE : " + urlToSave, Level.INFO); - sendHttpRequest(urlToSave, fileContentTosend, true); - logger.log("MESSAGE STATUS : " + messageStatus, Level.INFO); - logger.log("LAST MESSAGE RESULT : ", Level.INFO); - processReturn(messageResult); - - if ("true".equals(convertPdf)) { - if (pdfContentTosend == "null") { - endMessage = endMessage + " mais la conversion pdf n'a pas fonctionné (le document ne pourra pas être signé)"; - } - } - - logger.log("----------END SEND OF THE OBJECT----------", Level.INFO); - } else { - logger.log("RESPONSE KO", Level.WARNING); - } - logger.log("----------END EDIT OBJECT----------", Level.INFO); - - //delete tmp files - FileManager.deleteSpecificFilesOnDir(fileToDelete); - - //delete env libreoffice instance - File dir_app = new File(userLocalDirTmp+idApplet); - if (dir_app.exists()) { - Path directory = Paths.get(userLocalDirTmp+idApplet); - Files.walkFileTree(directory, new SimpleFileVisitor<Path>() { - @Override - public FileVisitResult visitFile(Path file, BasicFileAttributes attrs) throws IOException { - Files.delete(file); - return FileVisitResult.CONTINUE; - } - - @Override - public FileVisitResult postVisitDirectory(Path dir, IOException exc) throws IOException { - Files.delete(dir); - return FileVisitResult.CONTINUE; - } - }); - } - //delete env libreoffice convert instance - File dir_app_conv = new File(userLocalDirTmp+idApplet+"_conv"); - if (dir_app_conv.exists()) { - Path directory = Paths.get(userLocalDirTmp+idApplet+"_conv"); - Files.walkFileTree(directory, new SimpleFileVisitor<Path>() { - @Override - public FileVisitResult visitFile(Path file, BasicFileAttributes attrs) throws IOException { - Files.delete(file); - return FileVisitResult.CONTINUE; - } - - @Override - public FileVisitResult postVisitDirectory(Path dir, IOException exc) throws IOException { - Files.delete(dir); - return FileVisitResult.CONTINUE; - } - }); - } - - return "ok"; - } - - /** - * Launch the external program and wait his execution end - * @return boolean - */ - public Boolean launchProcess() throws PrivilegedActionException, InterruptedException, IllegalArgumentException, IllegalAccessException, InvocationTargetException { - Process proc; - - logger.log("LAUNCH THE EDITOR !", Level.INFO); - if ("linux".equals(os) || "mac".equals(os)) { - proc = fM.launchApp(appPath); - } else { - logger.log("FILE TO EDIT : " + userLocalDirTmp + fileToEdit, Level.INFO); - - String programName; - programName = fM.findGoodProgramWithExt(fileExtension); - logger.log("PROGRAM NAME TO EDIT : " + programName, Level.INFO); - String pathProgram; - pathProgram = fM.findPathProgramInRegistry(programName); - logger.log("PROGRAM PATH TO EDIT : " + pathProgram, Level.INFO); - String options; - options = fM.findGoodOptionsToEdit(fileExtension); - logger.log("OPTION PROGRAM TO EDIT " + options, Level.INFO); - String pathCommand; - if("".equals(options)){ - options = "\"-env:UserInstallation=file:///" + userLocalDirTmp.replace("\\", "/") + idApplet +"/\" "; - } - pathCommand = pathProgram + " " + options + "\"" + userLocalDirTmp + fileToEdit + "\""; - logger.log("PATH COMMAND TO EDIT " + pathCommand, Level.INFO); - proc = fM.launchApp(pathCommand); - } - proc.waitFor(); - logger.log("END OF THE PROCESS", Level.INFO); - - return true; - } - - /** - * Send an http request to Maarch - * @param theUrl url to contact Maarch - * @param postRequest the request - * @param endProcess end request - */ - public void sendHttpRequest(String theUrl, final String postRequest, final boolean endProcess) throws UnsupportedEncodingException { - System.out.println("URL request : " + theUrl); - - // Inner class representing the payload to be posted via HTTP - AbstractHttpEntity entity = new AbstractHttpEntity() { - public boolean isRepeatable() { - return false; // must be implemented - } - - public long getContentLength() { - return -1; // must be implemented - } - - public boolean isStreaming() { - return false; // must be implemented - } - - public InputStream getContent() throws IOException { - return new ByteArrayInputStream(postRequest.getBytes()); - } - - public void writeTo(OutputStream out) throws IOException { - System.out.println("METHOD 'WriteTo' WAS CALLED!"); - if (!"none".equals(postRequest)) { - Writer writer = new OutputStreamWriter(out, "UTF-8"); - // Using a StringBuffer rather than multiple "+" operators results in much better performance! - StringBuffer sb = new StringBuffer(); - if ("true".equals(convertPdf)) { - if (endProcess) { - // Prepending "null" saves from testing "if(pdfContentTosend != null)" - if ("null".equalsIgnoreCase(pdfContentTosend)) { - sb.append("fileContent="); - sb.append(fileContentTosend); - sb.append("&fileExtension="); - sb.append(fileExtension); - } else { - sb.append("fileContent="); - sb.append(fileContentTosend); - sb.append("&fileExtension="); - sb.append(fileExtension); - sb.append("&pdfContent="); - sb.append(pdfContentTosend); - } - } else { - sb.append("fileContent="); - sb.append(fileContentTosend); - sb.append("&fileExtension="); - sb.append(fileExtension); - } - } else { - sb.append("fileContent="); - sb.append(fileContentTosend); - sb.append("&fileExtension="); - sb.append(fileExtension); - } - - writer.write(sb.toString()); - writer.flush(); - } - } - }; - HttpPost request = new HttpPost(theUrl); // Construct a HTTP post request - System.out.println("BUILT REQUEST: " + request); - - - // Request parameters and other properties. - List<NameValuePair> params = new ArrayList<NameValuePair>(2); - - if ("true".equals(convertPdf)) { - if (endProcess) { - // Prepending "null" saves from testing "if(pdfContentTosend != null)" - if ("null".equalsIgnoreCase(pdfContentTosend)) { - params.add(new BasicNameValuePair("fileContent", fileContentTosend)); - params.add(new BasicNameValuePair("fileExtension", fileExtension)); - } else { - params.add(new BasicNameValuePair("fileContent", fileContentTosend)); - params.add(new BasicNameValuePair("fileExtension", fileExtension)); - params.add(new BasicNameValuePair("pdfContent", pdfContentTosend)); - } - } else { - params.add(new BasicNameValuePair("fileContent", fileContentTosend)); - params.add(new BasicNameValuePair("fileExtension", fileExtension)); - } - } else { - params.add(new BasicNameValuePair("fileContent", fileContentTosend)); - params.add(new BasicNameValuePair("fileExtension", fileExtension)); - } - - request.setEntity(new UrlEncodedFormEntity(params, "UTF-8")); - System.out.println("FULL REQUEST" + request); - try { - System.out.println("COOKIES TO BE SENT: " + httpContext.getCookieStore().getCookies()); // Show the cookies to be sent - CloseableHttpResponse response = httpClient.execute(request, httpContext); // Carry out the HTTP post request - System.out.println(response); - if (response == null) { - System.out.println("NO RESPONSE, THE APPLICATION WILL FAIL!"); - } else { - parse_xml(response.getEntity().getContent()); // Process the response from the server - response.close(); - } - } catch (Exception ex) { - logger.log("erreur: " + ex, Level.SEVERE); - JOptionPane.showMessageDialog(null, "ERREUR ! La connexion au serveur a été interrompue, le document édité n'a pas été sauvegardé !"); - } - } - - /** - * Class to manage the execution of an external program - */ - public class ProcessLoop extends Thread { - public DisCM disCM; - - public ProcessLoop(DisCM disCM){ - this.disCM = disCM; - } - - public void run() { - try { - disCM.launchProcess(); - } catch (PrivilegedActionException ex) { - Logger.getLogger(DisCM.class.getName()).log(Level.SEVERE, null, ex); - } catch (InterruptedException ex) { - Logger.getLogger(DisCM.class.getName()).log(Level.SEVERE, null, ex); - } catch (IllegalArgumentException ex) { - Logger.getLogger(DisCM.class.getName()).log(Level.SEVERE, null, ex); - } catch (IllegalAccessException ex) { - Logger.getLogger(DisCM.class.getName()).log(Level.SEVERE, null, ex); - } catch (InvocationTargetException ex) { - Logger.getLogger(DisCM.class.getName()).log(Level.SEVERE, null, ex); - } - } - } -} - diff --git a/modules/content_management/dist/srcDIS/FileManager.java b/modules/content_management/dist/srcDIS/FileManager.java deleted file mode 100755 index ff48982491f41325d4f41fcb96a58217b6d886b2..0000000000000000000000000000000000000000 --- a/modules/content_management/dist/srcDIS/FileManager.java +++ /dev/null @@ -1,348 +0,0 @@ -/** - * Jdk platform : 1.8 - */ - -/** - * SVN version 120 - */ - - -package com.dis; - -import java.io.*; -import java.lang.reflect.InvocationTargetException; -import java.security.AccessController; -import java.security.PrivilegedActionException; -import java.security.PrivilegedExceptionAction; -import org.apache.commons.codec.binary.Base64; - -import java.nio.file.Files; -import java.nio.file.Paths; -import java.util.List; - -/** - * FileManager class manages the exchange of files between the applet and the workstation - * @author Laurent Giovannoni - */ -public class FileManager { - - /** - * Creates the tmp dir - * @param path path to the tmp dir - */ - public String createUserLocalDirTmp(String path, String os) throws IOException { - File file=new File(path); - String msg = ""; - if (!file.exists()) { - System.out.println("directory " + path + " not exists so the applet will create it"); - if (file.mkdir()) { - System.out.println("Directory: " + path + " created"); - } else { - System.out.println("Directory: " + path + " not created"); - msg = "ERROR"; - } - } else { - System.out.println("directory " + path + " already exists"); - } - if (!file.setReadable(true, false)) { - System.out.println("set permission readable failed on : " + path); - msg = "ERROR"; - } - if (!file.setWritable(true, false) && !"win".equals(os)) { - System.out.println("set permission writable failed on : " + path); - msg = "ERROR"; - } - if (!file.setExecutable(true, false)) { - System.out.println("set permission executable failed on : " + path); - msg = "ERROR"; - } - return msg; - } - - /** - * Controls the existance of psExec file in tmp dir - * @param path path to the tmp dir - * @return boolean - */ - public boolean isPsExecFileExists(String path) throws IOException { - File file=new File(path); - if (!file.exists()) { - System.out.println("psExec on path " + path + " not exists so the applet will create it"); - return false; - } else { - System.out.println("psExec on path " + path + " already exists"); - return true; - } - } - - /** - * Creates the template sended by Maarch file in tmp dir - * @param encodedContent the file to create - * @param pathTofile directory of the file to create - * @return boolean - */ - public boolean createFile(String encodedContent, final String pathTofile) throws IOException, PrivilegedActionException{ - final byte[] decodedBytes = Base64.decodeBase64(encodedContent); - AccessController.doPrivileged(new PrivilegedExceptionAction() { - public Object run() throws IOException { - FileOutputStream fos = new FileOutputStream(pathTofile); - fos.write(decodedBytes); - fos.close(); - File file = new File(pathTofile); - if (!file.setReadable(true, false)) { - System.out.println("set permission readable failed on : " + pathTofile); - } - if (!file.setWritable(true, false)) { - System.out.println("set permission writable failed on : " + pathTofile); - } - if (!file.setExecutable(true, false)) { - System.out.println("set permission executable failed on : " + pathTofile); - } - return fos; - } - } - ); - return true; - } - - /** - * Creates the bat file to launch te editor of te template - * @param pathToBatFile path to the bat file - * @param pathToFileToLaunch path to the file to launch - * @param fileToLaunch name of the file to launch - * @param os os of the workstation - * @return boolean - */ - public boolean createBatFile( - final String pathToBatFile, - final String pathToFileToLaunch, - final String fileToLaunch, - final String os, - final String idApplet - ) throws IOException, PrivilegedActionException { - final Writer out; - if ("win".equals(os)) { - out = new OutputStreamWriter(new FileOutputStream(pathToBatFile), "CP850"); - } else { - out = new OutputStreamWriter(new FileOutputStream(pathToBatFile), "utf-8"); - } - AccessController.doPrivileged(new PrivilegedExceptionAction() { - public Object run() throws IOException { - if ("win".equals(os)) { - if (fileToLaunch.contains(".odt") || fileToLaunch.contains(".ods")) { - //out.write("start /WAIT SOFFICE.exe -env:UserInstallation=file:///" - // + pathToFileToLaunch.replace("\\", "/") + " \"" + pathToFileToLaunch + fileToLaunch + "\""); - out.write("start /WAIT SOFFICE.exe \"-env:UserInstallation=file:///" + pathToFileToLaunch.replace("\\", "/") + idApplet +"/\" \"" + pathToFileToLaunch + fileToLaunch + "\""); - } else { - out.write("start /WAIT \"\" \"" + pathToFileToLaunch + fileToLaunch + "\""); - } - } else if ("mac".equals(os)) { - out.write("open -W " + pathToFileToLaunch + fileToLaunch); - } else if ("linux".equals(os)) { - out.write("libreoffice -env:UserInstallation=file://" + pathToFileToLaunch + idApplet +"/ " + pathToFileToLaunch + fileToLaunch + " || ooffice " + pathToFileToLaunch + fileToLaunch +"& wait"); - } - out.close(); - File file = new File(pathToBatFile); - if (!file.setReadable(true, false)) { - System.out.println("set permission readable failed on : " + pathToBatFile); - } - if (!file.setWritable(true, false)) { - System.out.println("set permission writable failed on : " + pathToBatFile); - } - if (!file.setExecutable(true, false)) { - System.out.println("set permission executable failed on : " + pathToBatFile); - } - - return out; - } - } - ); - return true; - } - - /** - * Encodes a file in base64 - * @param fichier path to the file to encode - * @return string - * @throws java.lang.Exception - */ - public static String encodeFile(String fichier) throws Exception { - byte[] buffer = readFile(fichier); - byte[] encodedBytes = Base64.encodeBase64(buffer); - return new String(encodedBytes); - } - - /** - * Reads a file - * @param filename path to the file to read - * @return byte - */ - private static byte[] readFile(String filename) throws IOException { - byte[] fileToEncode = Files.readAllBytes(Paths.get(filename)); - return fileToEncode; - } - - /** - * Launchs a command to execute - * @param launchCommand the command to launch - * @return process - */ - public Process launchApp(final String launchCommand) throws PrivilegedActionException { - return (Process) AccessController.doPrivileged( - new PrivilegedExceptionAction() { - public Object run() throws IOException { - return Runtime.getRuntime().exec(launchCommand); - } - } - ); - } - - /** - * Launchs a command to execute - * @param launchCommand the command to launch - * @return process - */ - /*public Process launchApp(final String launchCommand) throws PrivilegedActionException { - System.out.println("COMMAND : " + launchCommand); - Object proc = new Object(); - try{ - proc = AccessController.doPrivileged( - new PrivilegedExceptionAction() { - - public Object run() throws IOException { - - Runtime rt = Runtime.getRuntime(); - Process proc = rt.exec(launchCommand); - String line; - BufferedReader in = new BufferedReader( - new InputStreamReader(proc.getInputStream()) ); - System.out.println("INFO: LAUNCH OF THE COMMAND -->"); - while ((line = in.readLine()) != null) { - System.out.println(line); - } - System.out.println("<--"); - in.close(); - - in = new BufferedReader( - new InputStreamReader(proc.getErrorStream()) ); - System.out.println("INFO: ERROR ON THE COMMAND -->"); - while ((line = in.readLine()) != null) { - System.out.println(line); - } - System.out.println("<--"); - in.close(); - - return proc; - - } - } - ); - } catch (Throwable t) - { - t.printStackTrace(); - } - return (Process) proc; - }*/ - - /** - * Retrieves the right program to edit the template with his extension - * @param ext extension of the template - * @return string - */ - public String findGoodProgramWithExt(String ext) { - String program = ""; - if ((ext.equalsIgnoreCase("docx") || ext.equalsIgnoreCase("doc") || ext.equalsIgnoreCase("docm"))) { - program = "winword.exe"; - } else if (ext.equalsIgnoreCase("xlsx") || ext.equalsIgnoreCase("xls") || ext.equalsIgnoreCase("xlsm")) { - program = "excel.exe"; - } else if (ext.equalsIgnoreCase("pptx") || ext.equalsIgnoreCase("ppt") || ext.equalsIgnoreCase("pptm") || ext.equalsIgnoreCase("ppsm")) { - program = "powerpnt.exe"; - } else { - program = "soffice.exe"; - } - - return program; - } - - /** - * Retrieves the path of a program in the registry - * @param program name of the program - * @return string - */ - public String findPathProgramInRegistry(String program) throws IllegalArgumentException, IllegalAccessException, InvocationTargetException { - String path; - path = WinRegistry.readString ( - WinRegistry.HKEY_LOCAL_MACHINE, //HKEY - "SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\App Paths\\" + program, //Key - ""); - return "\"" + path + "\""; - } - - /** - * Retrieves the right options to edit the template - * @param ext extension of the template - * @return string - */ - public String findGoodOptionsToEdit(String ext) { - String options = ""; - if ( - "docx".equals(ext.toLowerCase()) || - "doc".equals(ext.toLowerCase()) || - "docm".equals(ext.toLowerCase()) - ) { - options = " /n /dde "; - } else if ( - "xlsx".equals(ext.toLowerCase()) || - "xls".equals(ext.toLowerCase()) || - "xlsm".equals(ext.toLowerCase()) - ) { - options = " /x "; - } else if ( - "pptx".equals(ext.toLowerCase()) || - "ppt".equals(ext.toLowerCase()) || - "pptm".equals(ext.toLowerCase()) || - "ppsm".equals(ext.toLowerCase()) - ) { - options = " "; - } else { - //options = " -env:UserInstallation=$SYSUSERCONFIG "; - } - - return options; - } - - /** - * Deletes file in the tmp dir - * @param directory path of the tmp dir - * @param pattern pattern of files to delete - */ - public static void deleteFilesOnDir (String directory, String pattern) throws IOException { - File dir = new File(directory); - File[] directoryListing = dir.listFiles(); - if (directoryListing != null) { - for (File child : directoryListing) { - System.out.println("a file : " + child); - if (child.toString().contains(pattern)) { - System.out.println("a file with pattern : " + child); - child.delete(); - } - } - } - } - - /** - * Deletes specific files in the tmp dir - * @param files contains alls file to delete - * @throws java.io.IOException - */ - public static void deleteSpecificFilesOnDir (List<String> files) throws IOException { - for (String file : files) { - System.out.println("file to delete : " + file); - File theFile = new File(file); - if (theFile.exists()) { - theFile.delete(); - } - } - } - -} \ No newline at end of file diff --git a/modules/content_management/dist/srcDIS/MyLogger.java b/modules/content_management/dist/srcDIS/MyLogger.java deleted file mode 100755 index 643b89387c518455fc985bde6c76c53e0236ec29..0000000000000000000000000000000000000000 --- a/modules/content_management/dist/srcDIS/MyLogger.java +++ /dev/null @@ -1,58 +0,0 @@ -/** - * Jdk platform : 1.8 - */ - -/** - * SVN version 10 - */ - -package com.dis; - -import java.io.IOException; -import java.util.logging.FileHandler; -import java.util.logging.Level; -import java.util.logging.Logger; -import java.util.logging.SimpleFormatter; - -/** - * MyLogger class manages the log of the applet - * @author Laurent Giovannoni - */ -public class MyLogger { - - private String loggerFile; - private FileHandler fh; - private Logger logger; - - /** - * Prepares the log - * @param pathTologs path to the log file in the tmp dir - */ - MyLogger(String pathTologs) { - this.loggerFile = pathTologs + "DisCM.log"; - this.logger = Logger.getLogger("DisCM"); - try { - // This block configure the logger with handler and formatter - this.fh = new FileHandler(this.loggerFile, true); - this.logger.addHandler(this.fh); - this.logger.setLevel(Level.ALL); - SimpleFormatter formatter = new SimpleFormatter(); - this.fh.setFormatter(formatter); - // the following statement is used to log any messages - this.logger.log(Level.INFO,"init the logger"); - } catch (SecurityException e) { - System.out.println(e); - } catch (IOException e) { - System.out.println(e); - } - } - - /** - * Writes the log - * @param message message to write in the log file - * @param level level of the message - */ - public void log(String message, Level level) { - this.logger.log(level, message); - } -} \ No newline at end of file diff --git a/modules/content_management/dist/srcDIS/WinRegistry.java b/modules/content_management/dist/srcDIS/WinRegistry.java deleted file mode 100755 index cbcfd76f0e0661c40662e0db08779498835d89df..0000000000000000000000000000000000000000 --- a/modules/content_management/dist/srcDIS/WinRegistry.java +++ /dev/null @@ -1,396 +0,0 @@ -/** - * Jdk platform : 1.8 - */ - -/** - * SVN version 120 - */ - -package com.dis; - -import java.lang.reflect.InvocationTargetException; -import java.lang.reflect.Method; -import java.util.HashMap; -import java.util.Map; -import java.util.ArrayList; -import java.util.List; -import java.util.prefs.Preferences; - -/** - * WinRegistry class manages the access to the registry - */ -public class WinRegistry { - public static final int HKEY_CURRENT_USER = 0x80000001; - public static final int HKEY_LOCAL_MACHINE = 0x80000002; - public static final int REG_SUCCESS = 0; - public static final int REG_NOTFOUND = 2; - public static final int REG_ACCESSDENIED = 5; - - private static final int KEY_ALL_ACCESS = 0xf003f; - private static final int KEY_READ = 0x20019; - private static Preferences userRoot = Preferences.userRoot(); - private static Preferences systemRoot = Preferences.systemRoot(); - private static Class<? extends Preferences> userClass = userRoot.getClass(); - private static Method regOpenKey = null; - private static Method regCloseKey = null; - private static Method regQueryValueEx = null; - private static Method regEnumValue = null; - private static Method regQueryInfoKey = null; - private static Method regEnumKeyEx = null; - private static Method regCreateKeyEx = null; - private static Method regSetValueEx = null; - private static Method regDeleteKey = null; - private static Method regDeleteValue = null; - - static { - try { - regOpenKey = userClass.getDeclaredMethod("WindowsRegOpenKey", - new Class[] { int.class, byte[].class, int.class }); - regOpenKey.setAccessible(true); - regCloseKey = userClass.getDeclaredMethod("WindowsRegCloseKey", - new Class[] { int.class }); - regCloseKey.setAccessible(true); - regQueryValueEx = userClass.getDeclaredMethod("WindowsRegQueryValueEx", - new Class[] { int.class, byte[].class }); - regQueryValueEx.setAccessible(true); - regEnumValue = userClass.getDeclaredMethod("WindowsRegEnumValue", - new Class[] { int.class, int.class, int.class }); - regEnumValue.setAccessible(true); - regQueryInfoKey = userClass.getDeclaredMethod("WindowsRegQueryInfoKey1", - new Class[] { int.class }); - regQueryInfoKey.setAccessible(true); - regEnumKeyEx = userClass.getDeclaredMethod( - "WindowsRegEnumKeyEx", new Class[] { int.class, int.class, - int.class }); - regEnumKeyEx.setAccessible(true); - regCreateKeyEx = userClass.getDeclaredMethod( - "WindowsRegCreateKeyEx", new Class[] { int.class, - byte[].class }); - regCreateKeyEx.setAccessible(true); - regSetValueEx = userClass.getDeclaredMethod( - "WindowsRegSetValueEx", new Class[] { int.class, - byte[].class, byte[].class }); - regSetValueEx.setAccessible(true); - regDeleteValue = userClass.getDeclaredMethod( - "WindowsRegDeleteValue", new Class[] { int.class, - byte[].class }); - regDeleteValue.setAccessible(true); - regDeleteKey = userClass.getDeclaredMethod( - "WindowsRegDeleteKey", new Class[] { int.class, - byte[].class }); - regDeleteKey.setAccessible(true); - } - catch (Exception e) { - e.printStackTrace(); - } - } - - private WinRegistry() { } - - /** - * Read a value from key and value name - * @param hkey HKEY_CURRENT_USER/HKEY_LOCAL_MACHINE - * @param key - * @param valueName - * @return the value - * @throws IllegalArgumentException - * @throws IllegalAccessException - * @throws InvocationTargetException - */ - public static String readString(int hkey, String key, String valueName) - throws IllegalArgumentException, IllegalAccessException, - InvocationTargetException - { - if (hkey == HKEY_LOCAL_MACHINE) { - return readString(systemRoot, hkey, key, valueName); - } - else if (hkey == HKEY_CURRENT_USER) { - return readString(userRoot, hkey, key, valueName); - } - else { - throw new IllegalArgumentException("hkey=" + hkey); - } - } - - /** - * Read value(s) and value name(s) form given key - * @param hkey HKEY_CURRENT_USER/HKEY_LOCAL_MACHINE - * @param key - * @return the value name(s) plus the value(s) - * @throws IllegalArgumentException - * @throws IllegalAccessException - * @throws InvocationTargetException - */ - public static Map<String, String> readStringValues(int hkey, String key) - throws IllegalArgumentException, IllegalAccessException, - InvocationTargetException - { - if (hkey == HKEY_LOCAL_MACHINE) { - return readStringValues(systemRoot, hkey, key); - } - else if (hkey == HKEY_CURRENT_USER) { - return readStringValues(userRoot, hkey, key); - } - else { - throw new IllegalArgumentException("hkey=" + hkey); - } - } - - /** - * Read the value name(s) from a given key - * @param hkey HKEY_CURRENT_USER/HKEY_LOCAL_MACHINE - * @param key - * @return the value name(s) - * @throws IllegalArgumentException - * @throws IllegalAccessException - * @throws InvocationTargetException - */ - public static List<String> readStringSubKeys(int hkey, String key) - throws IllegalArgumentException, IllegalAccessException, - InvocationTargetException - { - if (hkey == HKEY_LOCAL_MACHINE) { - return readStringSubKeys(systemRoot, hkey, key); - } - else if (hkey == HKEY_CURRENT_USER) { - return readStringSubKeys(userRoot, hkey, key); - } - else { - throw new IllegalArgumentException("hkey=" + hkey); - } - } - - /** - * Create a key - * @param hkey HKEY_CURRENT_USER/HKEY_LOCAL_MACHINE - * @param key - * @throws IllegalArgumentException - * @throws IllegalAccessException - * @throws InvocationTargetException - */ - public static void createKey(int hkey, String key) - throws IllegalArgumentException, IllegalAccessException, - InvocationTargetException - { - int [] ret; - if (hkey == HKEY_LOCAL_MACHINE) { - ret = createKey(systemRoot, hkey, key); - regCloseKey.invoke(systemRoot, new Object[] { ret[0]}); - } - else if (hkey == HKEY_CURRENT_USER) { - ret = createKey(userRoot, hkey, key); - regCloseKey.invoke(userRoot, new Object[] { ret[0]}); - } - else { - throw new IllegalArgumentException("hkey=" + hkey); - } - if (ret[1] != REG_SUCCESS) { - throw new IllegalArgumentException("rc=" + ret[1] + " key=" + key); - } - } - - /** - * Write a value in a given key/value name - * @param hkey - * @param key - * @param valueName - * @param value - * @throws IllegalArgumentException - * @throws IllegalAccessException - * @throws InvocationTargetException - */ - public static void writeStringValue - (int hkey, String key, String valueName, String value) - throws IllegalArgumentException, IllegalAccessException, - InvocationTargetException - { - if (hkey == HKEY_LOCAL_MACHINE) { - writeStringValue(systemRoot, hkey, key, valueName, value); - } - else if (hkey == HKEY_CURRENT_USER) { - writeStringValue(userRoot, hkey, key, valueName, value); - } - else { - throw new IllegalArgumentException("hkey=" + hkey); - } - } - - /** - * Delete a given key - * @param hkey - * @param key - * @throws IllegalArgumentException - * @throws IllegalAccessException - * @throws InvocationTargetException - */ - public static void deleteKey(int hkey, String key) - throws IllegalArgumentException, IllegalAccessException, - InvocationTargetException - { - int rc = -1; - if (hkey == HKEY_LOCAL_MACHINE) { - rc = deleteKey(systemRoot, hkey, key); - } - else if (hkey == HKEY_CURRENT_USER) { - rc = deleteKey(userRoot, hkey, key); - } - if (rc != REG_SUCCESS) { - throw new IllegalArgumentException("rc=" + rc + " key=" + key); - } - } - - /** - * delete a value from a given key/value name - * @param hkey - * @param key - * @param value - * @throws IllegalArgumentException - * @throws IllegalAccessException - * @throws InvocationTargetException - */ - public static void deleteValue(int hkey, String key, String value) - throws IllegalArgumentException, IllegalAccessException, - InvocationTargetException - { - int rc = -1; - if (hkey == HKEY_LOCAL_MACHINE) { - rc = deleteValue(systemRoot, hkey, key, value); - } - else if (hkey == HKEY_CURRENT_USER) { - rc = deleteValue(userRoot, hkey, key, value); - } - if (rc != REG_SUCCESS) { - throw new IllegalArgumentException("rc=" + rc + " key=" + key + " value=" + value); - } - } - - // ===================== - - private static int deleteValue - (Preferences root, int hkey, String key, String value) - throws IllegalArgumentException, IllegalAccessException, - InvocationTargetException - { - int[] handles = (int[]) regOpenKey.invoke(root, new Object[] { - hkey, toCstr(key), KEY_ALL_ACCESS}); - if (handles[1] != REG_SUCCESS) { - return handles[1]; // can be REG_NOTFOUND, REG_ACCESSDENIED - } - int rc =((Integer) regDeleteValue.invoke(root, - new Object[] { - handles[0], toCstr(value) - })).intValue(); - regCloseKey.invoke(root, new Object[] { handles[0]}); - return rc; - } - - private static int deleteKey(Preferences root, int hkey, String key) - throws IllegalArgumentException, IllegalAccessException, - InvocationTargetException - { - int rc =((Integer) regDeleteKey.invoke(root, - new Object[] { hkey, toCstr(key) })).intValue(); - return rc; // can REG_NOTFOUND, REG_ACCESSDENIED, REG_SUCCESS - } - - private static String readString(Preferences root, int hkey, String key, String value) - throws IllegalArgumentException, IllegalAccessException, - InvocationTargetException - { - int[] handles = (int[]) regOpenKey.invoke(root, new Object[] { - hkey, toCstr(key), KEY_READ}); - if (handles[1] != REG_SUCCESS) { - return null; - } - byte[] valb = (byte[]) regQueryValueEx.invoke(root, new Object[] { - handles[0], toCstr(value) }); - regCloseKey.invoke(root, new Object[] { handles[0]}); - return (valb != null ? new String(valb).trim() : null); - } - - private static Map<String,String> readStringValues - (Preferences root, int hkey, String key) - throws IllegalArgumentException, IllegalAccessException, - InvocationTargetException - { - HashMap<String, String> results = new HashMap<String,String>(); - int[] handles = (int[]) regOpenKey.invoke(root, new Object[] { - hkey, toCstr(key), KEY_READ}); - if (handles[1] != REG_SUCCESS) { - return null; - } - int[] info = (int[]) regQueryInfoKey.invoke(root, - new Object[] { handles[0]}); - - int count = info[0]; // count - int maxlen = info[3]; // value length max - for(int index=0; index<count; index++) { - byte[] name = (byte[]) regEnumValue.invoke(root, new Object[] { - handles[0], index, maxlen + 1}); - String value = readString(hkey, key, new String(name)); - results.put(new String(name).trim(), value); - } - regCloseKey.invoke(root, new Object[] { handles[0]}); - return results; - } - - private static List<String> readStringSubKeys - (Preferences root, int hkey, String key) - throws IllegalArgumentException, IllegalAccessException, - InvocationTargetException - { - List<String> results = new ArrayList<String>(); - int[] handles = (int[]) regOpenKey.invoke(root, new Object[] { - hkey, toCstr(key), KEY_READ}); - if (handles[1] != REG_SUCCESS) { - return null; - } - int[] info = (int[]) regQueryInfoKey.invoke(root, - new Object[] { handles[0]}); - - int count = info[0]; // Fix: info[2] was being used here with wrong results. Suggested by davenpcj, confirmed by Petrucio - int maxlen = info[3]; // value length max - for(int index=0; index<count; index++) { - byte[] name = (byte[]) regEnumKeyEx.invoke(root, new Object[] { - handles[0], index, maxlen + 1}); - results.add(new String(name).trim()); - } - regCloseKey.invoke(root, new Object[] { handles[0]}); - return results; - } - - private static int [] createKey(Preferences root, int hkey, String key) - throws IllegalArgumentException, IllegalAccessException, - InvocationTargetException - { - return (int[]) regCreateKeyEx.invoke(root, - new Object[] { hkey, toCstr(key) }); - } - - private static void writeStringValue - (Preferences root, int hkey, String key, String valueName, String value) - throws IllegalArgumentException, IllegalAccessException, - InvocationTargetException - { - int[] handles = (int[]) regOpenKey.invoke(root, new Object[] { - hkey, toCstr(key), KEY_ALL_ACCESS}); - - regSetValueEx.invoke(root, - new Object[] { - handles[0], toCstr(valueName), toCstr(value) - }); - regCloseKey.invoke(root, new Object[] { handles[0]}); - } - - // utility - private static byte[] toCstr(String str) { - byte[] result = new byte[str.length() + 1]; - - for (int i = 0; i < str.length(); i++) { - result[i] = (byte) str.charAt(i); - } - result[str.length()] = 0; - return result; - } -} - diff --git a/modules/entities/Controllers/ListModelsController.php b/modules/entities/Controllers/ListModelsController.php index 87720a055f7db8b3e8fdc1d2e69c9c134cdcdb39..cafef8873b39c9e14fba08a7caa38d4d2f054e28 100755 --- a/modules/entities/Controllers/ListModelsController.php +++ b/modules/entities/Controllers/ListModelsController.php @@ -27,7 +27,7 @@ class ListModelsController public function getListModelsDiffListDestByUserId(RequestInterface $request, ResponseInterface $response, $aArgs) { - $return['listModels'] = ListModelsModel::getDiffListByUserId(['select' => ['object_id','description'], 'itemId' => $aArgs['itemId'],'objectType' => $aArgs['objectType'],'itemMode' => $aArgs['itemMode']]); + $return['listModels'] = ListModelsModel::getDiffListByUserId(['select' => ['object_id','title'], 'itemId' => $aArgs['itemId'],'objectType' => $aArgs['objectType'],'itemMode' => $aArgs['itemMode']]); return $response->withJson($return); } diff --git a/modules/entities/Models/EntityModelAbstract.php b/modules/entities/Models/EntityModelAbstract.php index 6715d62923a98ec89cdbb7812075afffab4bb0fd..da49cf51fe1a3791f5fe95840b773a7c820bc6e7 100755 --- a/modules/entities/Models/EntityModelAbstract.php +++ b/modules/entities/Models/EntityModelAbstract.php @@ -27,7 +27,8 @@ class EntityModelAbstract 'select' => empty($aArgs['select']) ? ['*'] : $aArgs['select'], 'table' => ['entities'], 'where' => ['enabled = ?'], - 'data' => ['Y'] + 'data' => ['Y'], + 'order_by' => ['entity_label'] ]); return $aEntities; @@ -148,13 +149,21 @@ class EntityModelAbstract $userEntities[] = $value['entity_id']; } - $allEntities = EntityModel::get(['select' => ['entity_id', 'entity_label']]); + $allEntities = EntityModel::get(['select' => ['entity_id', 'entity_label', 'parent_entity_id']]); foreach ($allEntities as $key => $value) { - if (in_array($value['entity_id'], $userEntities) || !in_array($value['entity_id'], $entitiesAllowedForAdministrator)) { - $allEntities[$key]['disabled'] = true; + $allEntities[$key]['id'] = $value['entity_id']; + if (empty($value['parent_entity_id'])) { + $allEntities[$key]['parent'] = '#'; + $allEntities[$key]['icon'] = "fa fa-building"; } else { - $allEntities[$key]['disabled'] = false; + $allEntities[$key]['parent'] = $value['parent_entity_id']; + $allEntities[$key]['icon'] = "fa fa-sitemap"; + } + $allEntities[$key]['text'] = $value['entity_label']; + if (in_array($value['entity_id'], $userEntities) || !in_array($value['entity_id'], $entitiesAllowedForAdministrator)) { + $allEntities[$key]['state']['opened'] = true; + $allEntities[$key]['state']['selected'] = true; } } diff --git a/modules/reports/xml/IVS/validation_rules.xml b/modules/reports/xml/IVS/validation_rules.xml index 8655087f3f29cfe9cdad7fb5552e30c54a962043..01dd8b5ce1fd363fcf6234b7d750eda1b10c762a 100755 --- a/modules/reports/xml/IVS/validation_rules.xml +++ b/modules/reports/xml/IVS/validation_rules.xml @@ -24,6 +24,8 @@ <parameter name="the_month" type="mois" /> <parameter name="the_year" type="annee" /> <parameter name="dir" type="string"/> + <parameter name="date_start" type="string"/> + <parameter name="date_fin" type="string"/> </validationRule> <validationRule name="users_logs" extends="standardForm" mode="error"> diff --git a/modules/visa/css/module.css b/modules/visa/css/module.css index 67ff8091b28cf773864f9e1a164fc1dd2cde1cda..1432db1310ad83f7cd33c89d92093af138cd37cb 100755 --- a/modules/visa/css/module.css +++ b/modules/visa/css/module.css @@ -19,6 +19,13 @@ float: left; } +#tabricatorLeft{ + height:99.5%; + min-width:0; + width:99.5%; + margin-bottom:0px; +} + #visa_right{ /*border:1px solid green;*/ height:95%; @@ -27,6 +34,12 @@ float: left; } +#tabricatorRight{ + height:90%; + min-width:0; + width:99.5%; +} + #visa_listDoc .toolbar{ height: 4%; width: 100%; @@ -135,6 +148,7 @@ opacity: 0.5 !important; color : #666 !important; border: solid 2px white !important; + text-decoration: line-through !important; } .droptarget input{ diff --git a/package.json b/package.json index 5c5deddb8155ddde5532d838a48d8f15867277f4..717a652a1d9b1906411004223ac3f4f67c03dfc7 100755 --- a/package.json +++ b/package.json @@ -17,7 +17,9 @@ "datatables": "^1.10.13", "jquery": "^3.2.1", "jquery-typeahead": "^2.8.0", - "jquery.nicescroll": "^3.6.8", + "jquery.nicescroll": "~3.6.8", + "jstree-bootstrap-theme": "^1.0.1", + "md2": "0.0.28", "photoswipe": "^4.1.2", "tinymce": "^4.6.2", "tooltipster": "^4.2.5", @@ -25,14 +27,14 @@ }, "devDependencies": { "@angular/animations": "^4.3.0", - "@angular/cdk": "^2.0.0-beta.8", + "@angular/cdk": "2.0.0-beta.8", "@angular/common": "^4.3.0", "@angular/compiler": "^4.3.0", "@angular/compiler-cli": "^4.3.0", "@angular/core": "^4.3.0", "@angular/forms": "^4.3.0", "@angular/http": "^4.3.1", - "@angular/material": "^2.0.0-beta.8", + "@angular/material": "2.0.0-beta.8", "@angular/platform-browser": "^4.3.0", "@angular/platform-browser-dynamic": "^4.3.0", "@angular/platform-server": "^4.3.0", diff --git a/rest/index.php b/rest/index.php index 97cb005d188b9ee8deb274ef75db350d3d2c3cb0..a76efeff405f44bb6d967c31ceabd5f9c090bbac 100755 --- a/rest/index.php +++ b/rest/index.php @@ -206,6 +206,13 @@ $app->get('/priorities/{id}', \Core\Controllers\PriorityController::class . ':ge $app->put('/priorities/{id}', \Core\Controllers\PriorityController::class . ':update'); $app->delete('/priorities/{id}', \Core\Controllers\PriorityController::class . ':delete'); +//History +$app->get('/administration/history/eventDate/{date}', \Core\Controllers\HistoryController::class . ':getForAdministration'); + +//HistoryBatch +$app->get('/administration/historyBatch/eventDate/{date}', \Core\Controllers\HistoryController::class . ':getBatchForAdministration'); + + //actions $app->get('/administration/actions', \Core\Controllers\ActionsController::class . ':getForAdministration'); $app->get('/initAction', \Core\Controllers\ActionsController::class . ':initAction');