<?php
require_once(dirname(__FILE__).'/init.php');
require_once(dirname(__FILE__).'/../page.php');
+$css = [];
+$js = [];
+if (!empty($_SERVER['DOCUMENT_ROOT'])) {
+ foreach (array_merge([]
+ ,glob($_SERVER['DOCUMENT_ROOT'].'/css/*.css')
+ ,glob($_SERVER['DOCUMENT_ROOT'].'/*.css')
+ ) as $c) {
+ $css[] = substr($c, strlen($_SERVER['DOCUMENT_ROOT']));
+ }
+ foreach (array_merge([]
+ ,[
+ $_SERVER['DOCUMENT_ROOT'].'/jquery/jquery.js',
+ $_SERVER['DOCUMENT_ROOT'].'/jquery/jquery-ui.js',
+ ]
+ ,glob($_SERVER['DOCUMENT_ROOT'].'/js/*.js')
+ ,glob($_SERVER['DOCUMENT_ROOT'].'/*.js')
+ )
+ as $j) {
+ if (file_exists($j)) $js[] = substr($j, strlen($_SERVER['DOCUMENT_ROOT']));
+ }
+ #debug([$js,$css]);
+}
+
$Page = new Page([
'title' => ($Db->title ? $Db->title : Db::prettyText($Db->name)),
+ 'css' => $css,
+ 'js' => $js,
'content_type' => Page::content_type_and_set_format(),
+ 'nav' => [
+ [ (!empty($Db) and !empty($Db->title)) ? $Db->title : 'Home', '/'],
+ ( (!empty($Table) and !empty($Table->name)) ? [Page::prettyText($Table->name),Page::path().'?table='.urlencode($Table->name)] : '' ),
+ ( Page::p('action') ? Page::prettyText(Page::p('action')) : '' ),
+ ],
'call' => array(
'begin',
#['out', "Hello World !!!\n"],
'end',
),
]);
+unset($js,$css);
--- /dev/null
+/*
+@import "/jquery/jquery-ui.css";
+::-moz-selection { background: #5babdf; color: #fff; text-shadow: none; }
+::selection { background: #5babdf; color: #fff; text-shadow: none; }
+*/
+
+/*
+See http://blog.javierusobiaga.com/stop-using-the-viewport-tag-until-you-know-ho
+@viewport{ zoom: 1.0; width: 320px; }
+@-ms-viewport{ width: 320px; zoom: 1.0; }
+border: solid 1px black;
+ width: auto;
+*/
+
+html {
+ background-color: #333;
+ font: 100% 'Trebuchet MS', sans-serif;
+}
+
+body {
+ color: #fff;
+ display: table;
+ margin-left: auto;
+ margin-right: auto;
+ padding-left: 1em;
+ padding-right: 1em;
+}
+
+#content {
+ width: 100%;
+}
+
+ul {
+ padding: 0;
+ margin: 0;
+}
+
+li {
+ list-style:none;
+ padding: 0 0 0 0.3em;
+}
+
+a[href] {
+ text-decoration: none;
+ color: #2A83BA;
+}
+
+hr {
+ clear: both;
+ margin: 0;
+ padding: 0.5px 0;
+ border: none;
+ background-color: #f4f4f4;
+}
+
+table { border-collapse: collapse; }
+td, th { padding: 0.2em 0.7em; }
+th { font-size: 0.8em; }
+select.Z,
+textarea,
+input:not([type]),
+input[type=''],
+input[type='text'] {
+ box-shadow: 0 0 5px 0 #eee;
+ border-radius: 4px;
+ border: solid 1px #eee;
+ padding: 0.4em;
+}
+
+.block,
+h1 a,
+.rows th a,
+.rad, .border, object, iframe, pre, .t2d tr {
+ background-color: #f8f8f8;
+ margin-bottom: 0.5em;
+ color: #444;
+}
+
+/*
+ Radius / Corners
+*/
+
+table.block,
+table.rad {
+ border-collapse: separate;
+ border-spacing: 0;
+}
+
+.block,
+.rad {
+ padding: 0.2em 0.1em;
+ border-radius: 4px;
+ -webkit-border-radius: 4px;
+ -moz-border-radius: 4px;
+}
+
+.block,
+.border {
+ border: solid 1px #ccc;
+}
+
+/*
+td.name,
+td.email,
+td.phone {
+ white-space: nowrap;
+}
+*/
+
+.rows div.list a {
+ list-style: disc inside none;
+ display: list-item;
+ /*
+ background:
+ url()
+ no-repeat
+ left center
+ ;
+ */
+}
+.rows div.list a.revision {
+ text-transform: capitalize;
+ list-style-type: circle;
+}
+/*
+.rows div.list a.revision:before {
+ content: ">";
+}
+*/
+.rows div.list {
+ white-space: nowrap;
+ margin: 0;
+ padding: 0 0.3em;
+ max-width: 10em;
+ height: 3.5em;
+ overflow: scroll;
+ border: solid 1px #ddd;
+ /*
+ opacity: 0.5;
+ */
+ border-radius: 4px;
+ -webkit-border-radius: 4px;
+ -moz-border-radius: 4px;
+}
+
+.small { font-size: 70%; }
+
+.db h1 {
+ display: inline-block;
+ padding: 0 0.2em;
+}
+
+/*
+table.border { border-bottom: none; }
+table.border td, table.border th { border-bottom: solid 1px #eee; }
+*/
+table.block th, table.block td,
+table.border th, table.border td {
+ border-bottom: solid 1px #eee;
+}
+
+table.block tr:last-child td, table.border tr:last-child td { border-bottom: none; }
+/*
+table.border tr.row:hover td:not([class~=action]) {
+*/
+table.block tr:hover td,
+table.border tr.row:hover td {
+ background-color: #f1f1f1;
+}
+
+div.rows .row li {
+ border-bottom: solid 0.1em #fafafa;
+}
+
+.options input[name="debug"] {
+ width: 2em;
+}
+
+/*
+ Markdown
+*/
+.db div.md {
+ /*
+ display: inline-block;
+ margin-left: 25%;
+ padding: 0.1em;
+ margin-top: -50px;
+ padding: 0;
+ padding: 0.3em;
+ float: right;
+ */
+ display: inline-block;
+}
+
+/*
+.db div.md p { margin: 0; padding: 0.2em 0.8em; }
+*/
+
+.inherit {
+ font-size: inherit;
+ font-family: inherit;
+ background-color: #fff;
+ border: none;
+}
+
+/*
+ Criterias
+ width: 16em;
+*/
+.menu {
+ font-size: 80%;
+ clear: both;
+}
+
+.menu select,
+.menu input:not([type=button]):not([type=password]):not([type=submit]) {
+ max-width: 8em;
+}
+
+.menu span {
+ border: solid 1px #f4f4f4;
+ /*
+ display: inline-block;
+ max-width: 28em;
+ */
+}
+
+.options {
+ border-bottom: solid 1px #f4f4f4;
+ margin-bottom: 0.1em;
+}
+
+@media (min-width: 400px) {
+ #_responsive {
+ content: none;
+ }
+ .t2d-th { display: none; }
+
+ .menu .buttons {
+ margin-left: auto;
+ margin-right: auto;
+ display: inline-block;
+ }
+
+ .menu .label {
+ display: inline-block;
+ }
+
+ .menu .label label {
+ display: inline-block;
+ text-align: right;
+ white-space: nowrap;
+ }
+
+ .db div.md { float: right; }
+
+
+}
+
+@media (max-width: 400px) {
+ #_responsive {
+ content: "400";
+ }
+ .menu .buttons {
+ display: block;
+ }
+ .label {
+ display: block;
+ }
+ .label label {
+ min-width: 25%;
+ display: inline-block;
+ vertical-align: middle;
+ }
+
+ .t2d {
+ /*
+ */
+ border: none;
+ border-radius: 0;
+ -webkit-border-radius: 0;
+ -moz-border-radius: 0;
+ box-shadow: none;
+ -webkit-box-shadow: none;
+ -moz-box-shadow: none;
+ background-color: inherit;
+ }
+ .t2d thead { display: none; }
+ .t2d tbody tr, .t2d tbody td { display: block; }
+ .t2d tr {
+ margin-bottom: 0.4em;
+ border-radius: 4px;
+ -webkit-border-radius: 4px;
+ -moz-border-radius: 4px;
+ padding: 0.2em 0.1em;
+ }
+ .t2d-th { min-width: 25%; display: inline-block; }
+
+}
+/* <<< @media */
+
+.button {
+ background-color: #ddd;
+ border: none;
+ color: #444;
+}
+
+.menu, .nav, .rows,
+.center {
+ margin-left: auto;
+ margin-right: auto;
+ display: table;
+}
+
+/*
+table.rows {
+ overflow: auto;
+}
+*/
+
+/*
+.debug {
+ max-width: 800px;
+ display: block;
+ overflow: scroll;
+}
+*/
+/*
+ See: http://www.ajaxload.info/
+*/
+.loading {
+ background:
+ url()
+ no-repeat
+ left center;
+}
--- /dev/null
+$(document).ready(function(){
+
+var nb = new NB({
+ 'ready': true,
+ 'resize': {
+ 'media_id': '_responsive',
+ 'table2div': 'table.rows',
+ 'maximize': '.embed',
+ 'resize_width': 'table, div',
+ },
+ 'debug': true,
+});
+
+var TABLE = $(':input[name="table"], #table, form select.tables').first().val();
+var DB = $(':input[name="db"], #db, form select.dbs').first().val();
+var PARAMS = $.param($(
+ ':input[value!=""][name="db"]:first'
+ +',:input[value!=""][name="table"]:first'
+ +',:input[value!=""][name="debug"]:first'
+));
+
+$('a.delete').href2delete('.nav',/(\d+)( \/ )(\d+)/);
+
+//var rb = document.getElementById('nav_bottom'); var rt = document.getElementById('nav_top'); if (rb && rt) rt.innerHTML = rb.innerHTML;
+$('.rows').each(function(){
+ var rows = $(this);
+ var nav = rows.next('.nav.bottom');
+ if (nav) {
+ //console.log ( nav.html() );
+ rows.before(nav.clone().attr('id','').removeClass('bottom').addClass('top'));
+ }
+});
+
+//$('<input type="button" onclick="nb.form_clear($(this).closest(\'form\')[0])" value="X"/>').prependTo('.criterias');
+var buttons = '<span class="buttons">'
+ //+'<input type="submit" class="button submit" value="GO"/>'
+ +'<input type="button" class="button table_add" value="Add" onclick="window.location = \'?action=edit&'+PARAMS+'\';"/>'
+// NB 03.04.16 +'<input type="button" class="button table_add" value="Add" onclick="window.location = \'?action=edit&table=\'+$(\'#table\').val()"/>'
+ //+'<input type="button" onclick="nb.form_clear($(this).closest(\'form\')[0])" value="X"/>'
+ +'<a href="#" class="button" onclick="nb.form_clear($(this).closest(\'form\')[0])">X</a>'
++'</span>';
+//$('.options .buttons').append( $('<input type="button" onclick="nb.form_clear($(this).closest(\'form\')[0])" value="X"/>') );
+$('.db form.menu .options').append( $(buttons) );
+
+// Class
+$('.nav, table.rows, center.rows .row, div.rows .row, .db.edit .fields, .menu, div.md').addClass('border rad');
+//$('.rows .doc').addClass('rad');
+$(':submit, :button, :reset').addClass('button');
+$('body > h1, .err').addClass('rad');
+
+// Replace with queries
+var sql = {
+ "SELECT '@id (' || count(*) || ')' FROM @id": ".menu .tables li a, .menu .tables li span",
+};
+for (var k in sql) { sql2html(k,sql[k]); }
+/*
+console.log($('#db-table-replace').text().split(' '));
+*/
+if ($('#db-table-replace').length>0) $.each($('#db-table-replace').text().split(' '),function(i,v){
+ v = v.split('.');
+ var r = v[0];
+ var t = v[1];
+ var f = v[2];
+ //console.log('.rows td.'+f+', .rows span.'+f+' | '+'SELECT '+f+' FROM '+t+" WHERE id='@id'");
+ sql2html('SELECT '+f+' FROM '+t+" WHERE id='@id'",'.rows td.'+r+', .rows span.'+r);
+ //console.log('SELECT '+f+' FROM '+t+" WHERE id='@id'"+" | "+'.rows td.'+r+', .rows span.'+r);
+});
+/*
+$('td.revision a').addClass('button').css('margin','0.1em auto');
+$('td.revision').css('text-align','center');
+*/
+
+// Path truncate
+nb.e2links('.rows td.doc, .rows span.doc, .rows td.url, .rows span.url');
+
+// Truncate
+$('.rows .description').each(function(){
+ $(this).text( nb.str_trunc($(this).text(),30) );
+});
+
+// Auto submit
+$('.db form.menu select').on('change',function(e){
+ //if ($(this).attr('name') == 'tables') alert(this.parentElement);
+ if ($(this).attr('class') == 'dbs') return false;
+ if ($(this).attr('name') == 'tables') nb.form_clear(this.parentElement);
+ //if ($(this).attr('name') == 'format' && $(this).val().match(/table/)) alert('zaza');
+ //if ($(this).attr('name') == 'format') alert($(this).val());
+ //console.log ($(this).attr('name'));
+ return $(this).closest('form').submit();
+});
+
+/*
+ <<< End
+ Functions >>>
+*/
+
+function zaza(sql) {
+console.log(db);
+ $.ajax({
+ type: 'GET',
+ url: 'index.php',
+ data: {
+ format: "json",
+ header: "0",
+ table: sql,
+ //table: encodeURI(sql),
+ },
+ contentType: 'application/json; charset=utf-8',
+ dataType: 'json',
+ success: function(data) {
+ console.log(data);
+ },
+ error: function() {
+ alert('Error loading '+url);
+ }
+ });
+return;
+ var url = 'index.php?format=json&header=0&table='+encodeURI(sql);
+ //alert(url);
+ var jqxhr = $.getJSON(url,function() {
+ //console.log( "success" );
+ })
+ .done(function(data) {
+ //console.log(data);
+ $.each( data, function(i,rec) {
+ console.log(rec['idtenant']);
+ });
+ console.log( "second success" );
+ })
+ .fail(function() {
+ //console.log( "error" );
+ })
+ .always(function() {
+ //console.log( "complete" );
+ });
+}
+
+function sql2url(sql) {
+ var db = DB;
+ return 'index.php?format=csv&header=0'
+ +(typeof db != 'undefined' ? '&db='+encodeURI(db) : '')
+ +'&table='+encodeURI(sql)
+ ;
+}
+
+function sql2html(sql,dom) {
+ //console.log('BUGGGGGGGGG !!!'); return;
+// TODO - NB 09.04.16 if (!this.cache) this.cache = {};
+
+ $(dom).each(function(){
+
+ item = $(this)
+ id = $(this).text(); if ((typeof id == 'undefined') || id == '' ) return;
+ url = sql2url(sql.replace(/@id/g,id.trim().replace("'","\\'")));
+ //console.log('dom='+dom+' id='+id+' url='+url);
+ //$(this).addClass('loading');
+ $(this).load(url,function(){$(this).removeClass('loading')});
+ return;
+
+ });
+ return $(dom);
+ /*
+ id = $(dom); if (id.length == 0) return;
+ id = id.html(); if (typeof id == 'undefined') return;
+
+ sql = sql.replace(/@id/,id.replace("'","\\'"));
+
+ console.log('dom='+dom+' id='+id+' sql='+sql);
+ $.ajax({
+
+ type: "GET",
+ url: sql2url(sql),
+ // data: "table=" + sql, // appears as $_GET['id'] @ ur backend side
+ success: function(data) {
+ // data is ur summary
+ if (data == '') return;
+ //data = data.replace('@id',id);
+ console.log(' '+dom+'=<'+data.trim()+'>');
+ //$(dom).html(data);
+ }
+
+ });
+ */
+}
+
+}); // $(document).ready(function(){