Merge pull request #154 from WDKevin/modern
Add support to change order of monitors
This commit is contained in:
commit
08e224f2af
|
@ -1,17 +1,17 @@
|
|||
<?php
|
||||
class MonitorsController extends AppController {
|
||||
public $helpers = array('LiveStream');
|
||||
public $helpers = array('LiveStream', 'Js'=>array('Jquery'));
|
||||
|
||||
public function index() {
|
||||
$zmBandwidth = $this->Cookie->read('zmBandwidth');
|
||||
$this->set('width', Configure::read('ZM_WEB_LIST_THUMB_WIDTH'));
|
||||
$monitoroptions = array( 'fields' => array('Name', 'Id', 'Function', 'Enabled'), 'recursive' => -1);
|
||||
$this->set('monitors', $this->Monitor->find('all', $monitoroptions));
|
||||
$this->set('width', Configure::read('ZM_WEB_LIST_THUMB_WIDTH'));
|
||||
$monitoroptions = array('fields' => array('Name', 'Id', 'Function', 'Enabled', 'Sequence'), 'order' => 'Sequence ASC', 'recursive' => -1);
|
||||
$this->set('monitors', $this->Monitor->find('all', $monitoroptions));
|
||||
$monitors = $this->Monitor->find('all', array('recursive' => -1, 'fields' => array('Id', 'StreamReplayBuffer')));
|
||||
foreach ($monitors as $monitor => $mon) {
|
||||
$streamSrc[$monitor] = $this->Monitor->getStreamSrc($monitor['Monitor']['Id'], $zmBandwidth, $monitor['Monitor']['StreamReplayBuffer']);
|
||||
}
|
||||
$this->set('streamSrc', $streamSrc);
|
||||
$this->set('streamSrc', $streamSrc);
|
||||
}
|
||||
|
||||
public function view($id = null) {
|
||||
|
@ -34,117 +34,117 @@
|
|||
|
||||
public function edit($id = null) {
|
||||
if (!$id) {
|
||||
throw new NotFoundException(__('Invalid monitor'));
|
||||
throw new NotFoundException(__('Invalid monitor'));
|
||||
}
|
||||
|
||||
$monitor = $this->Monitor->findById($id);
|
||||
if (!$monitor) {
|
||||
throw new NotFoundException(__('Invalid monitor'));
|
||||
}
|
||||
$this->set('monitor', $monitor['Monitor']);
|
||||
throw new NotFoundException(__('Invalid monitor'));
|
||||
}
|
||||
$this->set('monitor', $monitor['Monitor']);
|
||||
|
||||
$typeoptions = array(
|
||||
'Local' => 'Local',
|
||||
'Remote' => 'Remote',
|
||||
'File' => 'File',
|
||||
'Ffmpeg' => 'Ffmpeg'
|
||||
);
|
||||
$this->set('typeoptions', $typeoptions);
|
||||
$typeoptions = array(
|
||||
'Local' => 'Local',
|
||||
'Remote' => 'Remote',
|
||||
'File' => 'File',
|
||||
'Ffmpeg' => 'Ffmpeg'
|
||||
);
|
||||
$this->set('typeoptions', $typeoptions);
|
||||
|
||||
$functionoptions = array(
|
||||
'Modect' => 'Modect',
|
||||
'Monitor' => 'Monitor',
|
||||
'Record' => 'Record',
|
||||
'None' => 'None',
|
||||
'Nodect' => 'Nodect',
|
||||
'Mocord' => 'Mocord'
|
||||
);
|
||||
$this->set('functionoptions', $functionoptions);
|
||||
$functionoptions = array(
|
||||
'Modect' => 'Modect',
|
||||
'Monitor' => 'Monitor',
|
||||
'Record' => 'Record',
|
||||
'None' => 'None',
|
||||
'Nodect' => 'Nodect',
|
||||
'Mocord' => 'Mocord'
|
||||
);
|
||||
$this->set('functionoptions', $functionoptions);
|
||||
|
||||
$protocoloptions = array(
|
||||
'rtsp' => 'RTSP',
|
||||
'http' => 'HTTP'
|
||||
);
|
||||
$this->set('protocoloptions', $protocoloptions);
|
||||
$protocoloptions = array(
|
||||
'rtsp' => 'RTSP',
|
||||
'http' => 'HTTP'
|
||||
);
|
||||
$this->set('protocoloptions', $protocoloptions);
|
||||
|
||||
$methodoptions = array(
|
||||
'simple' => 'Simple',
|
||||
'regexp' => 'Regexp'
|
||||
);
|
||||
$this->set('methodoptions', $methodoptions);
|
||||
$methodoptions = array(
|
||||
'simple' => 'Simple',
|
||||
'regexp' => 'Regexp'
|
||||
);
|
||||
$this->set('methodoptions', $methodoptions);
|
||||
|
||||
$optionsColours = array(
|
||||
1 => '8 bit grayscale',
|
||||
3 => '24 bit color',
|
||||
4 => '32 bit color'
|
||||
);
|
||||
$this->set('optionsColours', $optionsColours);
|
||||
$optionsColours = array(
|
||||
1 => '8 bit grayscale',
|
||||
3 => '24 bit color',
|
||||
4 => '32 bit color'
|
||||
);
|
||||
$this->set('optionsColours', $optionsColours);
|
||||
|
||||
$channeloptions = array();
|
||||
for ($i=1; $i<32; $i++) {
|
||||
array_push($channeloptions, $i);
|
||||
}
|
||||
$this->set('channeloptions', $channeloptions);
|
||||
$channeloptions = array();
|
||||
for ($i=1; $i<32; $i++) {
|
||||
array_push($channeloptions, $i);
|
||||
}
|
||||
$this->set('channeloptions', $channeloptions);
|
||||
|
||||
$formatoptions = array(
|
||||
255 => "PAL",
|
||||
45056 => "NTSC",
|
||||
1 => "PAL B",
|
||||
2 => "PAL B1",
|
||||
4 => "PAL G",
|
||||
8 => "PAL H",
|
||||
16 => "PAL I",
|
||||
32 => "PAL D",
|
||||
64 => "PAL D1",
|
||||
128 => "PAL K",
|
||||
256 => "PAL M",
|
||||
512 => "PAL N",
|
||||
1024 => "PAL Nc",
|
||||
2048 => "PAL 60",
|
||||
4096 => "NTSC M",
|
||||
8192 => "NTSC M JP",
|
||||
16384 => "NTSC 443",
|
||||
32768 => "NTSC M KR",
|
||||
65536 => "SECAM B",
|
||||
131072 => "SECAM D",
|
||||
262144 => "SECAM G",
|
||||
524288 => "SECAM H",
|
||||
1048576 => "SECAM K",
|
||||
2097152 => "SECAM K1",
|
||||
4194304 => "SECAM L",
|
||||
8388608 => "SECAM LC",
|
||||
16777216 => "ATSC 8 VSB",
|
||||
33554432 => "ATSC 16 VSB"
|
||||
);
|
||||
$this->set('formatoptions', $formatoptions);
|
||||
$formatoptions = array(
|
||||
255 => "PAL",
|
||||
45056 => "NTSC",
|
||||
1 => "PAL B",
|
||||
2 => "PAL B1",
|
||||
4 => "PAL G",
|
||||
8 => "PAL H",
|
||||
16 => "PAL I",
|
||||
32 => "PAL D",
|
||||
64 => "PAL D1",
|
||||
128 => "PAL K",
|
||||
256 => "PAL M",
|
||||
512 => "PAL N",
|
||||
1024 => "PAL Nc",
|
||||
2048 => "PAL 60",
|
||||
4096 => "NTSC M",
|
||||
8192 => "NTSC M JP",
|
||||
16384 => "NTSC 443",
|
||||
32768 => "NTSC M KR",
|
||||
65536 => "SECAM B",
|
||||
131072 => "SECAM D",
|
||||
262144 => "SECAM G",
|
||||
524288 => "SECAM H",
|
||||
1048576 => "SECAM K",
|
||||
2097152 => "SECAM K1",
|
||||
4194304 => "SECAM L",
|
||||
8388608 => "SECAM LC",
|
||||
16777216 => "ATSC 8 VSB",
|
||||
33554432 => "ATSC 16 VSB"
|
||||
);
|
||||
$this->set('formatoptions', $formatoptions);
|
||||
|
||||
$optionsPalette = array(
|
||||
0 => 'Auto',
|
||||
1497715271 => 'Gray',
|
||||
877807426 => 'BGR32',
|
||||
876758866 => 'RGB32',
|
||||
861030210 => 'BGR24',
|
||||
859981650 => 'RGB24',
|
||||
1448695129 => '*YUYV',
|
||||
1195724874 => '*JPEG',
|
||||
1196444237 => '*MJPEG',
|
||||
875836498 => '*RGB444',
|
||||
1329743698 => '*RGB555',
|
||||
1346520914 => '*RGB565',
|
||||
1345466932 => '*YUV422P',
|
||||
1345401140 => '*YUV411P',
|
||||
875836505 => '*YUV444',
|
||||
961959257 => '*YUV410',
|
||||
842093913 => '*YUV420'
|
||||
);
|
||||
$this->set('optionsPalette', $optionsPalette);
|
||||
$optionsPalette = array(
|
||||
0 => 'Auto',
|
||||
1497715271 => 'Gray',
|
||||
877807426 => 'BGR32',
|
||||
876758866 => 'RGB32',
|
||||
861030210 => 'BGR24',
|
||||
859981650 => 'RGB24',
|
||||
1448695129 => '*YUYV',
|
||||
1195724874 => '*JPEG',
|
||||
1196444237 => '*MJPEG',
|
||||
875836498 => '*RGB444',
|
||||
1329743698 => '*RGB555',
|
||||
1346520914 => '*RGB565',
|
||||
1345466932 => '*YUV422P',
|
||||
1345401140 => '*YUV411P',
|
||||
875836505 => '*YUV444',
|
||||
961959257 => '*YUV410',
|
||||
842093913 => '*YUV420'
|
||||
);
|
||||
$this->set('optionsPalette', $optionsPalette);
|
||||
|
||||
$optionsMethod = array(
|
||||
'v4l2' => 'Video For Linux 2'
|
||||
);
|
||||
$this->set('optionsMethod', $optionsMethod);
|
||||
$optionsMethod = array(
|
||||
'v4l2' => 'Video For Linux 2'
|
||||
);
|
||||
$this->set('optionsMethod', $optionsMethod);
|
||||
|
||||
$this->set('linkedMonitors', $this->Monitor->find('list', array('fields' => array('Id', 'Name'))));
|
||||
$this->set('linkedMonitors', $this->Monitor->find('list', array('fields' => array('Id', 'Name'))));
|
||||
|
||||
if ($this->request->is('put') || $this->request->is('post')) {
|
||||
$this->Monitor->id = $id;
|
||||
|
@ -161,18 +161,26 @@
|
|||
}
|
||||
}
|
||||
|
||||
public function add() {
|
||||
if ($this->request->is('post')) {
|
||||
$this->Monitor->create();
|
||||
if ($this->Monitor->save($this->request->data)) {
|
||||
$this->Session->setFlash('Your monitor has been created.');
|
||||
$this->redirect(array('action' => 'index'));
|
||||
} else {
|
||||
$this->Session->setFlash('Unable to create your monitor.');
|
||||
}
|
||||
}
|
||||
}
|
||||
public function add() {
|
||||
if ($this->request->is('post')) {
|
||||
$this->Monitor->create();
|
||||
if ($this->Monitor->save($this->request->data)) {
|
||||
$this->Session->setFlash('Your monitor has been created.');
|
||||
$this->redirect(array('action' => 'index'));
|
||||
} else {
|
||||
$this->Session->setFlash('Unable to create your monitor.');
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public function reorder() {
|
||||
foreach ($this->data['Monitor'] as $key => $value) {
|
||||
$this->log($value);
|
||||
$this->Monitor->id = $value;
|
||||
$this->Monitor->saveField('Sequence', $key + 1);
|
||||
}
|
||||
exit();
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
?>
|
|
@ -3,9 +3,10 @@
|
|||
echo $this->Html->link( 'Add Monitor', array('controller' => 'monitors', 'action' => 'add'));
|
||||
$this->end();
|
||||
?>
|
||||
<div class="row">
|
||||
|
||||
<div class="row" id="monitors">
|
||||
<?php foreach ($monitors as $monitor => $mon): ?>
|
||||
<div class="col-sm-6 col-md-3">
|
||||
<div class="col-sm-6 col-md-3" id="Monitor_<?= $mon['Monitor']['Sequence']; ?>">
|
||||
<div class="thumbnail">
|
||||
<?php
|
||||
if($daemonStatus && $mon['Monitor']['Function'] != "None" && $mon['Monitor']['Enabled'])
|
||||
|
@ -22,3 +23,8 @@
|
|||
<?php endforeach; ?>
|
||||
<?php unset($monitor); ?>
|
||||
</div>
|
||||
|
||||
<?php
|
||||
$this->Js->get('#monitors');
|
||||
$this->Js->sortable(array('complete' => '$.post("/monitors/reorder", $("#monitors").sortable("serialize"))',));
|
||||
?>
|
Loading…
Reference in New Issue