Этот коммит содержится в:
Igor V Belousov 2017-01-23 02:47:24 +03:00
родитель 9744d67202
Коммит 6644a5a52d
21 изменённых файлов: 649 добавлений и 9 удалений

4
.gitignore поставляемый
Просмотреть файл

@ -1,2 +1,4 @@
.idea/* .idea/*
grunt/node_modules/* grunt/node_modules/*
vendor/*
composer.lock

34
README.md Обычный файл
Просмотреть файл

@ -0,0 +1,34 @@
PTEST
=====
Задание
-------
###Написать Доску объявлений
Доска объявлений предоставляет возможность пользователям сайта оставлять
сообщения на сайте.
Все данные введенные пользователем сохраняются в БД MySQL, так же в базе данных
сохраняются данные о IP пользователя и его браузере.
Форма добавления записи на доску объявлений должна иметь следующие поля:
* User Name (цифры и буквы латинского алфавита) – обязательное поле
* E-mail (формат email) — обязательное поле
* Homepage (формат url) – необязательное поле
* CAPTCHA (цифры и буквы латинского алфавита) – изображение и обязательное
поле (http://ru.wikipedia.org/wiki/CAPTCHA)
* Text (непосредственно сам текст сообщения, HTML тэги недопустимы) –
обязательное поле
Сообщения должны выводится в виде таблицы, с возможностью сортировки по
следующим полям: User Name, e-mail, и дата добавления (как в порядке убывания,
так и в обратном). Сообщения должны разбиваться на страницы по 25 сообщений на
каждой.
Приветствуется создания простейшего дизайна с использованием CSS.
Развертывание
-------------

Просмотреть файл

@ -11,7 +11,8 @@
], ],
"autoload": { "autoload": {
"psr-4": { "psr-4": {
"PTEST\\": ["src/"] "PTEST\\": ["src/"],
"PFRM\\": ["frm/"]
} }
}, },
"require": { "require": {

22
frm/App.php Обычный файл
Просмотреть файл

@ -0,0 +1,22 @@
<?php
/**
* Created by PhpStorm.
* User: Игорь
* Date: 23.01.2017
* Time: 01:58
*/
namespace FRM;
class App {
function __construct() {
date_default_timezone_set('Europe/Moscow');
error_reporting(E_ALL);
}
function run(){
}
}

18
frm/Controller.php Обычный файл
Просмотреть файл

@ -0,0 +1,18 @@
<?php
/**
* Created by PhpStorm.
* User: Игорь
* Date: 23.01.2017
* Time: 01:49
*/
namespace FRM;
class Controller {
function __construct() {
session_start();
}
}

14
frm/View.php Обычный файл
Просмотреть файл

@ -0,0 +1,14 @@
<?php
/**
* Created by PhpStorm.
* User: Игорь
* Date: 23.01.2017
* Time: 02:45
*/
namespace FRM;
class View {
}

Просмотреть файл

@ -1,3 +1,50 @@
/** module.exports = function(grunt) {
* Created by Игорь on 23.01.2017.
*/ grunt.initConfig({
pkg: grunt.file.readJSON('package.json'),
uglify: {
frontpage: {
src: 'js/*.js',
dest: '../public/js/script.js'
}
},
stylus: {
compile: {
options:{
compress:false
},
files: {
"../public/css/style.raw.css":'css/style.styl'
}
}
},
csso: {
search: {
files: {
'../public/css/style.css':'../public/css/style.raw.css'
}
}
}
});
grunt.loadNpmTasks('grunt-contrib-jshint');
grunt.loadNpmTasks('grunt-contrib-internal');
grunt.loadNpmTasks('grunt-contrib-uglify');
grunt.loadNpmTasks('grunt-csso');
grunt.loadNpmTasks('grunt-contrib-stylus');
grunt.registerTask('css',['stylus','csso']);
grunt.registerTask('js',['uglify']);
grunt.registerTask('default', ['css']);
grunt.registerTask('full',['css','js'])
};

Просмотреть файл

@ -1,3 +1,30 @@
@import "ShortCSS/ShortCSS.styl" @import "ShortCSS/ShortCSS.styl"
@import "normalize/normalize.styl" @import "normalize/normalize.styl"
/** ptest css */
$link_color = #0063ff
$link_color_border = alpha($link_color,.3)
$link_hover_color = #ff475d
$link_hover_color_border = alpha($link_hover_color,.24)
$link_visited_color = #cf00cf
$link_visited_color_border = alpha($link_visited_color,.3)
a
-c $link_color
-td none
-brb 1 solid $link_color_border
&:visited
-c $link_visited_color
-brbc $link_visited_color_border
&:hover
&:visited:hover
-c $link_hover_color
-brbc $link_hover_color_border
.page
&__container
-wmax 800

55
grunt/js/bindReady.js Обычный файл
Просмотреть файл

@ -0,0 +1,55 @@
/*
* http://javascript.ru/tutorial/events/ondomcontentloaded
* bindReady(function(){alert('dom load')})
*/
function bindReady(handler){
var called = false
function ready() { // (1)
if (called) return
called = true
handler()
}
if ( document.addEventListener ) { // (2)
document.addEventListener( "DOMContentLoaded", function(){
ready()
}, false )
} else if ( document.attachEvent ) { // (3)
// (3.1)
if ( document.documentElement.doScroll && window == window.top ) {
function tryScroll(){
if (called) return
if (!document.body) return
try {
document.documentElement.doScroll("left")
ready()
} catch(e) {
setTimeout(tryScroll, 0)
}
}
tryScroll()
}
// (3.2)
document.attachEvent("onreadystatechange", function(){
if ( document.readyState === "complete" ) {
ready()
}
})
}
// (4)
if (window.addEventListener)
window.addEventListener('load', ready, false)
else if (window.attachEvent)
window.attachEvent('onload', ready)
/* else // (4.1)
window.onload=ready
*/
}

58
grunt/js/foreach.js Обычный файл
Просмотреть файл

@ -0,0 +1,58 @@
// Production steps of ECMA-262, Edition 5, 15.4.4.18
// Reference: http://es5.github.io/#x15.4.4.18
if (!Array.prototype.forEach) {
Array.prototype.forEach = function(callback, thisArg) {
var T, k;
if (this == null) {
throw new TypeError(' this is null or not defined');
}
// 1. Let O be the result of calling ToObject passing the |this| value as the argument.
var O = Object(this);
// 2. Let lenValue be the result of calling the Get internal method of O with the argument "length".
// 3. Let len be ToUint32(lenValue).
var len = O.length >>> 0;
// 4. If IsCallable(callback) is false, throw a TypeError exception.
// See: http://es5.github.com/#x9.11
if (typeof callback !== "function") {
throw new TypeError(callback + ' is not a function');
}
// 5. If thisArg was supplied, let T be thisArg; else let T be undefined.
if (arguments.length > 1) {
T = thisArg;
}
// 6. Let k be 0
k = 0;
// 7. Repeat, while k < len
while (k < len) {
var kValue;
// a. Let Pk be ToString(k).
// This is implicit for LHS operands of the in operator
// b. Let kPresent be the result of calling the HasProperty internal method of O with argument Pk.
// This step can be combined with c
// c. If kPresent is true, then
if (k in O) {
// i. Let kValue be the result of calling the Get internal method of O with argument Pk.
kValue = O[k];
// ii. Call the Call internal method of callback with T as the this value and
// argument list containing kValue, k, and O.
callback.call(T, kValue, k, O);
}
// d. Increase k by 1.
k++;
}
// 8. return undefined
};
}

1
grunt/js/index.js Обычный файл
Просмотреть файл

@ -0,0 +1 @@

91
grunt/js/xmlhttp.js Обычный файл
Просмотреть файл

@ -0,0 +1,91 @@
//xmlHttpConnect
//xH.conn(URL,Method,Vars,Function done) - assync
//xH.syn(URL,Method,Vars) - sync, return result query
function xH()
{
var xmlhttp, bComplete = false;
try
{
xmlhttp = new ActiveXObject("Msxml2.XMLHTTP");
}catch (e)
{
try
{
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}catch (e)
{
try
{
xmlhttp = new XMLHttpRequest();
}catch (e)
{
xmlhttp = false;
}
}
}
if (!xmlhttp) return null;
this.syn = function(sURL, sMethod, sVars)
{
if (!xmlhttp) return false;
sMethod = sMethod.toUpperCase();
if (sMethod == "GET")
{
xmlhttp.open(sMethod,sURL+"?"+sVars,false);
xmlhttp.send(null);
if (xmlhttp.status == 200)
{
return xmlhttp.responseText;
}
return false;
}
else
{
xmlhttp.open(sMethod, sURL, false);
xmlhttp.setRequestHeader("Method", "POST "+sURL+" HTTP/1.1");
xmlhttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
xmlhttp.send(sVars);
if (xmlhttp.status == 200)
{
return xmlhttp.responseText;
}
return false;
}
}
this.conn = function(sURL, sMethod, sVars, fnDone)
{
if (!xmlhttp) return false;
bComplete = false;
sMethod = sMethod.toUpperCase();
try
{
if (sMethod == "GET")
{
xmlhttp.open(sMethod, sURL+"?"+sVars, true);
sVars = "";
}
else
{
xmlhttp.open(sMethod, sURL, true);
xmlhttp.setRequestHeader("Method", "POST "+sURL+" HTTP/1.1");
xmlhttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
xmlhttp.send(sVars);
}
xmlhttp.onreadystatechange = function()
{
if (xmlhttp.readyState == 4 && !bComplete)
{
bComplete = true;
fnDone(xmlhttp);
}
};
xmlhttp.send(sVars);
}
catch(z)
{
return false;
}
return true;
};
return this;
}

Просмотреть файл

@ -1,4 +1,12 @@
{ {
"name": "ptest", "name": "ptest",
"version": "0.0.1" "version": "0.0.1",
"devDependencies": {
"grunt": "~0.4.1",
"grunt-csso": "~0.5.0",
"grunt-contrib-stylus": "~1.2.0",
"grunt-contrib-jshint": "~1.0.0",
"grunt-contrib-internal": "~1.2.2",
"grunt-contrib-uglify": "~2.0.0"
}
} }

6
public/.htaccess Обычный файл
Просмотреть файл

@ -0,0 +1,6 @@
<IfModule mod_rewrite.c>
RewriteEngine On
RewriteCond %{REQUEST_FILENAME} !-f
RewriteRule ^(.*)$ index.php [QSA,L]
</IfModule>

1
public/css/style.css Обычный файл
Просмотреть файл

@ -0,0 +1 @@
html{font-family:sans-serif;line-height:1.15;-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%}body{margin:0}article,aside,footer,header,nav,section{display:block}h1{font-size:2em;margin:.67em 0}figcaption,figure,main{display:block}figure{margin:1em 40px}hr{box-sizing:content-box;height:0;overflow:visible}pre{font-family:monospace,monospace;font-size:1em}a{background-color:transparent;-webkit-text-decoration-skip:objects}a:active,a:hover{outline-width:0}abbr[title]{border-bottom:none;text-decoration:underline dotted}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace,monospace;font-size:1em}dfn{font-style:italic}mark{background-color:#ff0;color:#000}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}audio,video{display:inline-block}audio:not([controls]){display:none;height:0}img{border-style:none}svg:not(:root){overflow:hidden}button,input,optgroup,select,textarea{font-family:sans-serif;font-size:100%;line-height:1.15;margin:0}button,input{overflow:visible}button,select{text-transform:none}button,html [type="button"],[type="reset"],[type="submit"]{-webkit-appearance:button}button::-moz-focus-inner,[type="button"]::-moz-focus-inner,[type="reset"]::-moz-focus-inner,[type="submit"]::-moz-focus-inner{border-style:none;padding:0}button:-moz-focusring,[type="button"]:-moz-focusring,[type="reset"]:-moz-focusring,[type="submit"]:-moz-focusring{outline:1px dotted ButtonText}fieldset{border:1px solid silver;margin:0 2px;padding:.35em .625em .75em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal}progress{display:inline-block;vertical-align:baseline}textarea{overflow:auto}[type="checkbox"],[type="radio"]{box-sizing:border-box;padding:0}[type="number"]::-webkit-inner-spin-button,[type="number"]::-webkit-outer-spin-button{height:auto}[type="search"]{-webkit-appearance:textfield;outline-offset:-2px}[type="search"]::-webkit-search-cancel-button,[type="search"]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}details,menu{display:block}summary{display:list-item}canvas{display:inline-block}template,[hidden]{display:none}a{color:#0063ff;text-decoration:none;border-bottom:1px solid rgba(0,99,255,.3)}a:visited{color:#cf00cf;border-bottom-color:rgba(207,0,207,.3)}a:hover,a:visited:hover{color:#ff475d;border-bottom-color:rgba(255,71,93,.24)}.page__container{max-width:800px}

215
public/css/style.raw.css Обычный файл
Просмотреть файл

@ -0,0 +1,215 @@
/* normalize.css v5.0.0 | MIT License | github.com/necolas/normalize.css */
html {
font-family: sans-serif;
line-height: 1.15;
-ms-text-size-adjust: 100%;
-webkit-text-size-adjust: 100%;
}
body {
margin: 0;
}
article,
aside,
footer,
header,
nav,
section {
display: block;
}
h1 {
font-size: 2em;
margin: 0.67em 0;
}
figcaption,
figure,
main {
display: block;
}
figure {
margin: 1em 40px;
}
hr {
box-sizing: content-box;
height: 0;
overflow: visible;
}
pre {
font-family: monospace, monospace;
font-size: 1em;
}
a {
background-color: transparent;
-webkit-text-decoration-skip: objects;
}
a:active,
a:hover {
outline-width: 0;
}
abbr[title] {
border-bottom: none;
text-decoration: underline;
text-decoration: underline dotted;
}
b,
strong {
font-weight: inherit;
}
b,
strong {
font-weight: bolder;
}
code,
kbd,
samp {
font-family: monospace, monospace;
font-size: 1em;
}
dfn {
font-style: italic;
}
mark {
background-color: #ff0;
color: #000;
}
small {
font-size: 80%;
}
sub,
sup {
font-size: 75%;
line-height: 0;
position: relative;
vertical-align: baseline;
}
sub {
bottom: -0.25em;
}
sup {
top: -0.5em;
}
audio,
video {
display: inline-block;
}
audio:not([controls]) {
display: none;
height: 0;
}
img {
border-style: none;
}
svg:not(:root) {
overflow: hidden;
}
button,
input,
optgroup,
select,
textarea {
font-family: sans-serif;
font-size: 100%;
line-height: 1.15;
margin: 0;
}
button,
input {
overflow: visible;
}
button,
select {
text-transform: none;
}
button,
html [type="button"],
[type="reset"],
[type="submit"] {
-webkit-appearance: button;
}
button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
border-style: none;
padding: 0;
}
button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
outline: 1px dotted ButtonText;
}
fieldset {
border: 1px solid #c0c0c0;
margin: 0 2px;
padding: 0.35em 0.625em 0.75em;
}
legend {
box-sizing: border-box;
color: inherit;
display: table;
max-width: 100%;
padding: 0;
white-space: normal;
}
progress {
display: inline-block;
vertical-align: baseline;
}
textarea {
overflow: auto;
}
[type="checkbox"],
[type="radio"] {
box-sizing: border-box;
padding: 0;
}
[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
height: auto;
}
[type="search"] {
-webkit-appearance: textfield;
outline-offset: -2px;
}
[type="search"]::-webkit-search-cancel-button,
[type="search"]::-webkit-search-decoration {
-webkit-appearance: none;
}
::-webkit-file-upload-button {
-webkit-appearance: button;
font: inherit;
}
details,
menu {
display: block;
}
summary {
display: list-item;
}
canvas {
display: inline-block;
}
template {
display: none;
}
[hidden] {
display: none;
}
/** ptest css */
a {
color: #0063ff;
text-decoration: none;
border-bottom: 1px solid rgba(0,99,255,0.3);
}
a:visited {
color: #cf00cf;
border-bottom-color: rgba(207,0,207,0.3);
}
a:hover,
a:visited:hover {
color: #ff475d;
border-bottom-color: rgba(255,71,93,0.24);
}
.page__container {
max-width: 800px;
}

Просмотреть файл

@ -4,4 +4,6 @@
* User: Игорь * User: Игорь
* Date: 23.01.2017 * Date: 23.01.2017
* Time: 00:21 * Time: 00:21
*/ */
require_once __DIR__ . '/../src/start.php';

1
public/js/script.js Обычный файл
Просмотреть файл

@ -0,0 +1 @@
function bindReady(a){function b(){d||(d=!0,a())}function c(){if(!d&&document.body)try{document.documentElement.doScroll("left"),b()}catch(a){setTimeout(c,0)}}var d=!1;document.addEventListener?document.addEventListener("DOMContentLoaded",function(){b()},!1):document.attachEvent&&(document.documentElement.doScroll&&window==window.top&&c(),document.attachEvent("onreadystatechange",function(){"complete"===document.readyState&&b()})),window.addEventListener?window.addEventListener("load",b,!1):window.attachEvent&&window.attachEvent("onload",b)}function xH(){var a,b=!1;try{a=new ActiveXObject("Msxml2.XMLHTTP")}catch(b){try{a=new ActiveXObject("Microsoft.XMLHTTP")}catch(b){try{a=new XMLHttpRequest}catch(b){a=!1}}}return a?(this.syn=function(b,c,d){return!!a&&(c=c.toUpperCase(),"GET"==c?(a.open(c,b+"?"+d,!1),a.send(null),200==a.status&&a.responseText):(a.open(c,b,!1),a.setRequestHeader("Method","POST "+b+" HTTP/1.1"),a.setRequestHeader("Content-Type","application/x-www-form-urlencoded"),a.send(d),200==a.status&&a.responseText))},this.conn=function(c,d,e,f){if(!a)return!1;b=!1,d=d.toUpperCase();try{"GET"==d?(a.open(d,c+"?"+e,!0),e=""):(a.open(d,c,!0),a.setRequestHeader("Method","POST "+c+" HTTP/1.1"),a.setRequestHeader("Content-Type","application/x-www-form-urlencoded"),a.send(e)),a.onreadystatechange=function(){4!=a.readyState||b||(b=!0,f(a))},a.send(e)}catch(a){return!1}return!0},this):null}Array.prototype.forEach||(Array.prototype.forEach=function(a,b){var c,d;if(null==this)throw new TypeError(" this is null or not defined");var e=Object(this),f=e.length>>>0;if("function"!=typeof a)throw new TypeError(a+" is not a function");for(arguments.length>1&&(c=b),d=0;d<f;){var g;d in e&&(g=e[d],a.call(c,g,d,e)),d++}});

Просмотреть файл

@ -9,6 +9,8 @@
namespace PTEST; namespace PTEST;
class IndexController { use FRM\Controller;
class IndexController extends Controller {
} }

Просмотреть файл

@ -11,4 +11,33 @@ namespace PTEST;
class AdModel { class AdModel {
protected $id;
protected $username;
protected $email;
protected $ip;
protected $browser;
protected $text;
protected $date;
function __construct() {
}
public function setUserName() {
}
public function getUserName(){
return $this->username;
}
public function getEmail() {
return $this->email;
}
} }

Просмотреть файл

@ -4,4 +4,10 @@
* User: Игорь * User: Игорь
* Date: 23.01.2017 * Date: 23.01.2017
* Time: 00:07 * Time: 00:07
*/ */
require_once __DIR__ . '/../vendor/autoload.php';
$app = new \FRM\App();
$app->run();