Built motion from commit a9fb64cc6defd8fb3a5cc199221f878e91c0e969. Version 3.0.0...
[motion-next.git] / public / src / js / modules / main / apps / analytics / views / metrics / metrics.html / metrics.html
1 <div
2   id="metrics"
3   class="page-layout simple left-sidenav inner-sidenav motion-list"
4 >
5   <!-- HEADER -->
6   <div
7     class="header md-accent-bg"
8     layout="row"
9     layout-align="space-between center"
10   >
11     <!-- APP TITLE -->
12     <div layout="row" layout-align="start center">
13       <div class="logo" layout="row" layout-align="start center">
14         <span class="logo-icon">
15           <md-icon md-font-icon="icon-chart-line" class="s24"></md-icon>
16         </span>
17         <span class="logo-text" translate="ANALYTICS.METRICS">Metrics</span>
18       </div>
19     </div>
20     <!-- / APP TITLE -->
21
22     <div layout="row">
23       <!-- SEARCH -->
24       <div
25         class="search-input-wrapper"
26         layout="row"
27         layout-align="start center"
28       >
29         <label for="search">
30           <md-icon md-font-icon="icon-magnify"></md-icon>
31         </label>
32         <md-input-container md-no-float class="m-0">
33           <input
34             id="search"
35             placeholder="Search for anyone"
36             type="text"
37             ng-model="vm.query.filter"
38             ng-model-options="{ debounce: 1000 }"
39             translate
40             translate-attr-placeholder="ANALYTICS.SEARCH_FOR_ANYONE"
41           />
42         </md-input-container>
43       </div>
44       <!-- / SEARCH -->
45     </div>
46   </div>
47   <!-- / HEADER -->
48
49   <!-- SELECTED BAR -->
50   <div
51     ng-show="vm.selectedMetrics.length > 0"
52     class="selected-bar header animate-slide-down md-accent-bg"
53     layout="row"
54     layout-align="start center"
55   >
56     <div class="close-button-wrapper" ng-click="vm.selectedMetrics =[]">
57       <md-button layout="row" layout-align="start center">
58         <md-icon md-font-icon="icon-arrow-left" class="mr-8"></md-icon>
59         <span translate="ANALYTICS.BACK">Back</span>
60       </md-button>
61     </div>
62
63     <div flex layout="row" layout-align="space-between center">
64       <div>
65         <span class="selected-metrics-count">
66           <span>{{vm.selectedMetrics.length}}</span>
67           <span translate="ANALYTICS.SELECTED">selected</span>
68         </span>
69
70         <md-menu class="select-menu" ng-if="!vm.currentThread">
71           <md-button
72             class="md-icon-button"
73             ng-click="$mdMenu.open($event)"
74             aria-label="multi select toggle"
75             translate
76             translate-attr-aria-label="ANALYTICS.MULTI_SELECT_TOGGLE"
77           >
78             <md-icon md-font-icon="icon-menu-down"></md-icon>
79           </md-button>
80           <md-menu-content width="3">
81             <md-menu-item>
82               <md-button
83                 ng-click="vm.selectAllMetrics()"
84                 translate="ANALYTICS.SELECT_ALL"
85               >
86                 Select all
87               </md-button>
88             </md-menu-item>
89             <md-menu-item>
90               <md-button
91                 ng-click="vm.deselectMetrics()"
92                 translate="ANALYTICS.SELECT_NONE"
93               >
94                 Select none
95               </md-button>
96             </md-menu-item>
97           </md-menu-content>
98         </md-menu>
99       </div>
100
101       <div class="multi-select-actions">
102         <button
103           class="md-icon-button"
104           ng-csv="vm.exportSelectedMetrics"
105           csv-label="true"
106           filename="metrics.csv"
107         >
108           <md-icon md-font-icon="icon-file-excel"></md-icon>
109         </button>
110         <md-button
111           class="md-icon-button"
112           ng-if="vm.crudPermissions.canDelete"
113           ng-click="vm.deleteSelectedMetrics($event)"
114           aria-label="delete selected"
115           translate
116           translate-attr-label="ANALYTICS.DELETE_SELECTED"
117         >
118           <md-icon md-font-icon="icon-delete"></md-icon>
119         </md-button>
120       </div>
121     </div>
122   </div>
123   <!-- / SELECTED BAR -->
124
125   <!-- CONTENT -->
126   <div class="content" md-background-bg layout="row" layout-align="start start">
127     <!-- MAIN -->
128     <div class="main scrollable" ms-scroll>
129       <!-- METRIC TABLE -->
130       <md-card>
131         <md-table-container>
132           <table
133             md-table
134             md-row-select
135             multiple
136             ng-model="vm.selectedMetrics"
137             md-progress="vm.promise"
138           >
139             <thead
140               md-head
141               md-order="vm.query.sort"
142               md-on-reorder="vm.getMetrics"
143             >
144               <tr md-row>
145                 <th
146                   md-column
147                   ng-if="vm.table == 'users' || vm.table == 'agents'"
148                   width="20px"
149                 ></th>
150                 <th md-column md-order-by="id">
151                   {{ 'ANALYTICS.ID' | translate }}
152                 </th>
153                 <th md-column md-order-by="name">
154                   {{ 'ANALYTICS.NAME' | translate }}
155                 </th>
156                 <th md-column md-order-by="table">
157                   {{ 'ANALYTICS.TABLE' | translate }}
158                 </th>
159                 <th md-column md-order-by="description">
160                   {{ 'ANALYTICS.DESCRIPTION' | translate }}
161                 </th>
162                 <th md-column width="10px"></th>
163               </tr>
164             </thead>
165             <tbody md-body>
166               <tr md-row ng-hide="vm.metrics.rows.length">
167                 <td md-cell colspan="5">
168                   <div layout="row" layout-align="center center">
169                     <span translate="ANALYTICS.NO_AVAILABLE_INFO"
170                       >No Available Info</span
171                     >
172                   </div>
173                 </td>
174               </tr>
175               <tr
176                 md-row
177                 md-select="metric"
178                 md-select-id="id"
179                 ng-repeat="metric in vm.metrics.rows"
180               >
181                 <td md-cell ng-if="metric.userpic">
182                   <img
183                     class="avatar"
184                     alt="{{metric.name}}"
185                     ng-src="api/users/{{metric.id}}/avatar"
186                   />
187                 </td>
188                 <td
189                   md-cell
190                   ng-if="!metric.userpic && (vm.table == 'users' || vm.table == 'agents')"
191                 >
192                   <img
193                     class="avatar"
194                     alt="{{metric.name}}"
195                     ng-src="assets/images/avatars/profile.png"
196                   />
197                 </td>
198                 <td
199                   ng-click="vm.createOrEditMetric($event, metric)"
200                   md-cell
201                   class="id"
202                 >
203                   {{metric.id}}
204                 </td>
205                 <td
206                   ng-click="vm.createOrEditMetric($event, metric)"
207                   md-cell
208                   class="name"
209                 >
210                   {{metric.name}}
211                 </td>
212                 <td
213                   ng-click="vm.createOrEditMetric($event, metric)"
214                   md-cell
215                   class="table"
216                 >
217                   {{ vm.arraytable[metric.table].option }}
218                 </td>
219                 <td
220                   ng-click="vm.createOrEditMetric($event, metric)"
221                   md-cell
222                   class="description"
223                 >
224                   {{metric.description}}
225                 </td>
226
227                 <td
228                   md-cell
229                   class="actions"
230                   ng-if="!vm.crudPermissions.readOnly"
231                 >
232                   <md-menu>
233                     <md-button
234                       class="md-icon-button"
235                       aria-label="More"
236                       translate
237                       translate-attr-aria-label="ANALYTICS.MORE"
238                       ng-click="$mdMenu.open($event)"
239                     >
240                       <md-icon md-font-icon="icon-dots-vertical"></md-icon>
241                     </md-button>
242
243                     <md-menu-content width="3">
244                       <!-- SUBACTIONS -->
245
246                       <!-- ACTIONS -->
247
248                       <md-menu-item ng-if="vm.crudPermissions.canEdit">
249                         <md-button
250                           ng-click="vm.editdialog(metric, $event    )"
251                           translate="ANALYTICS.EDIT_METRIC"
252                         >
253                           Edit Metric
254                         </md-button>
255                       </md-menu-item>
256
257                       <!-- SUBACTIONS -->
258
259                       <!-- ACTIONS -->
260
261                       <md-menu-item ng-if="vm.crudPermissions.canDelete">
262                         <md-button
263                           ng-click="vm.deleteconfirm(metric, $event    )"
264                           translate="ANALYTICS.DELETE_METRIC"
265                         >
266                           Delete Metric
267                         </md-button>
268                       </md-menu-item>
269                     </md-menu-content>
270                   </md-menu>
271                 </td>
272               </tr>
273             </tbody>
274           </table>
275         </md-table-container>
276
277         <md-table-pagination
278           md-label="{page: '{{'ANALYTICS.PAGE' | translate}}:', rowsPerPage: '{{'ANALYTICS.ROWSPERPAGE' | translate}}:', of: '{{'ANALYTICS.OF' | translate}}'}"
279           md-limit="vm.query.limit"
280           md-limit-options="[10, 15, 20, 50, 100, 250]"
281           md-page="vm.query.page"
282           md-total="{{vm.metrics.count}}"
283           md-on-paginate="vm.getMetrics"
284           md-page-select
285         ></md-table-pagination>
286       </md-card>
287       <!-- / METRIC TABLE -->
288       <!-- NO RESULTS -->
289
290       <!-- / NO RESULTS -->
291     </div>
292     <!-- / MAIN -->
293   </div>
294   <!-- / CONTENT -->
295
296   <!-- ADD METRIC BUTTON -->
297   <md-button
298     ng-if="vm.crudPermissions.canEdit"
299     class="md-fab md-accent add-item-button"
300     id="add-metric-button"
301     ng-click="vm.createOrEditMetric($event)"
302     aria-label="add metric"
303     translate
304     translate-attr-aria-label="ANALYTICS.ADD_METRIC"
305   >
306     <md-icon md-font-icon="icon-plus"></md-icon>
307   </md-button>
308   <!-- / ADD METRIC BUTTON -->
309 </div>