const inputs = document.querySelector('.profile-settings');
inputs.addEventListener('click', e => {
const target = e.target;
if(target.tagName === 'DIV') {
const input = target.previousElementSibling;
input.disabled = !input.disabled;
target.textContent = input.disabled ? '<i class=\'far fa-edit\'></i>' : '<i class=\'far fa-save inputing\'></i>';
}
});
<div class="passport-page">
<header>
<div id="left-content">
<span>Passport</span>
</div>
<div id="right-content">
<a href="../index.html">Exit</a>
<nav>
<img src="" id="save" alt="Save the changes">
<img src="" id="exit" alt="Exit">
</nav>
</div>
</header>
<main>
<div id="left-content">
<form action="" method="post" class="profile-settings">
<div class="editor">
<label for="login">Login</label>
<input type="text" name="login" value="Jack D" disabled="true">
<div id="control"><i class="far fa-edit" aria-hidden="true"></i></div>
</div>
<div class="editor">
<label for="mail">E-Mail</label>
<input type="email" name="mail" value="jack@gmail.com" disabled="true">
<div id="control"><i class="far fa-edit" aria-hidden="true"></i></div>
</div>
<div class="editor">
<label for="pass">Password</label>
<input type="password" name="pass" value="123456" disabled="true">
<div id="control"><i class="far fa-edit" aria-hidden="true"></i></div>
</div>
<div class="editor">
<label for="fname">First name</label>
<input type="text" name="fname" value="Daniels" disabled="true">
<div id="control"><i class="far fa-edit" aria-hidden="true"></i></div>
</div>
<div class="editor">
<label for="sname">Second name</label>
<input type="text" name="sname" value="" disabled="true">
<div id="control"><i class="far fa-edit" aria-hidden="true"></i></div>
</div>
<div class="editor">
<label for="login">Fone</label>
<input type="text" name="fone" value="" disabled="true">
<div id="control"><i class="far fa-edit" aria-hidden="true"></i></div>
</div>
</form>
</div>
<div id="right-content">
<ul class="nav">
<li class="active"><i class="fas fa-circle" aria-hidden="true"></i><a href="">Passport</a></li>
<li><i class="fas fa-circle" aria-hidden="true"></i><a href="">My investment requests</a></li>
<li><i class="fas fa-circle" aria-hidden="true"></i><a href="">My offers for investors</a></li>
<li><i class="fas fa-circle" aria-hidden="true"></i><a href="">My services for investors</a></li>
<li><i class="fas fa-circle" aria-hidden="true"></i><a href="">My shopping Cart</a></li>
</ul>
</div>
</main>
<footer>
<div id="left-content">
<button class="add-but">Save the changes</button>
</div>
</footer>
</div>
@import url('../passport.css');
#passport {
height: 410px;
}
.passport-page {
height: calc(284px * 2);
}
.passport-page > main #left-content .profile-settings{
width: 50%;
}
.passport-page > main #left-content .profile-settings .editor{
display: block;
margin-top: 2%;
}
.passport-page > main #left-content .profile-settings .editor label{
display: block;
margin-top: 8px;
font-size: 80%;
margin-left: 2%;
color: gray;
}
.passport-page > main #left-content .profile-settings .editor input{
background-color: white;
font-size: 90%;
color:black;
border: solid 2px darkgray;
padding: 5px;
font-weight: bold;
text-indent: 2%;
margin-top: 12px;
width: 86%;
border-radius: 4px;
padding-top: 2%;
padding-bottom: 2%;
margin-left: 2%;
}
.passport-page > main #left-content .profile-settings .editor #control{
font-size: 100%;
display: inline-table;
margin-top: 15px;
color: gray;
margin-left: 2%;
}
.passport-page > main #left-content .profile-settings .editor #control:hover{
cursor: pointer;
}
.passport-page > main #left-content .profile-settings .editor #control i.inputing{
color: #0079bf;
}
.passport-page > main #left-content .profile-settings .editor input:focus{
border-color:#0079bf;
}
.passport-page > main #left-content .profile-settings .editor input:disabled{
font-weight: normal;
color: gray;
}
.passport-page > footer{
position: relative;
top: -32%;
}
.passport-page > footer #left-content{
width: 100%;
top: 60px;
position: relative;
}
@media all and (max-width: 414px){
#passport {
height: 590px;
}
}
@media all and (max-width: 600px){
#passport {
height: 590px;
}
}
@media all and (max-width: 768px){
#passport {
height: 590px;
}
.passport-page {
height: calc(313px * 2);
}
}
@media all and (max-width: 800px){
#passport {
height: 590px;
}
.passport-page {
height: calc(313px * 2);
}
}
@media all and (max-width: 960px){
#passport {
height: 590px;
}
.passport-page > main #left-content .profile-settings .editor input{
width: 80%;
}
.passport-page > main #left-content .profile-settings {
width: 98%;
}
.passport-page {
height: calc(313px * 2);
}
}
@media all and (max-width: 1024px){
#passport {
height: 590px;
}
.passport-page {
height: calc(313px * 2);
}
}
@media all and (max-width: 1280px){
#passport {
height: 680px;
}
}
$(document).ready(function () {
$('.passport-page > main #left-content .profile-settings .editor').click(function (e,t) {
const target = $(this);
if (target.prop("tagName") === 'div' && target.attr('id') === 'control') {
const input = target.prevAll('input').first();
input.attr('disabled', !input.attr('disabled'));
if(input.attr('disabled')){
target.html("<i class='far fa-save inputing'></i>");
}
else{
target.html("<i class='far fa-edit'></i>");
}
}
});
});
import React, {Component, useState, useEffect} from 'react';
import { Button, View, Text, SafeAreaView, FlatList, StyleSheet, StatusBar } from 'react-native';
import _ from "lodash";
import {Categories} from "../data/Categories";
import {Cards} from "../data/Cards";
import {CategoryItem} from "../components/CategoryItem";
import {CardItem} from "../components/CardItem";
import { Audio } from 'expo-av';
const styles = StyleSheet.create({
container: {
flex: 1,
},
item: {
backgroundColor: '#c2e3ff',
padding: 20,
height: 10,
marginVertical: 8,
marginHorizontal: 16,
},
title: {
fontSize: 12,
},
})
export class HomeScreen extends Component {
constructor(props) {
super(props);
this.state = {catSelect: 1, shelf:[]};
}
onCatPress = (item) => {
console.log('onCatPress');
this.setState({ catSelect: item.key });
console.log(this.state);
};
onCardPress = (item) => {
console.log('onCardPress');
let music;
let shelf = this.state.shelf;
shelf.push(item);
this.setState({ shelf: shelf });
console.log(this.state.shelf);
if(item.sound != null) music = item.sound;
else music = '../assets/sounds/nosound.wav';
const [ setSound ] = useState();
useEffect(() => {
(async () => {
const snd = Audio.fromModule(music);
await snd.downloadAsync();
const notify = await Audio.Sound.createAsync(snd.localUri || snd.uri);
setSound(notify);
await notify.asyncPlay();
})();
}, []);
};
renderCat = ({item}) => {
return (
<CategoryItem
category={item}
onPress={this.onCatPress.bind(this, item)}
/>
);
};
renderCard = ({item}) => {
return (
<CardItem
card={item}
onPress={this.onCardPress.bind(this, item)}
/>
);
};
render = () => {
var sortedCat = _.filter(Cards, {'categorie': this.state.catSelect})
return (
<View style={{ flex: 1, alignItems: 'center', justifyContent: 'center' }}>
<Text>Главный экран</Text>
<View style={styles.container}>
<FlatList
data={this.state.shelf}
renderItem={this.renderCard}
keyExtractor={item => item.id.toString()}
onPress={this.onCatPress.bind(this)}
horizontal={true}
/>
</View>
<View style={styles.container}>
<FlatList
data={sortedCat}
renderItem={this.renderCard}
keyExtractor={item => item.id.toString()}
onPress={this.onCatPress.bind(this)}
horizontal={true}
/>
</View>
<View style={styles.container}>
<FlatList
data={Categories}
renderItem={this.renderCat}
keyExtractor={item => item.key.toString()}
onPress={this.onCatPress.bind(this)}
horizontal={true}
/>
</View>
<Button
title="Категории карточек"
onPress={() => this.props.navigation.push('Categories')} />
</View>
)
}
}
import React, {Component, useState, useEffect} from 'react';
import {StyleSheet, TouchableOpacity, Image, Text, View} from 'react-native';
import { Asset } from 'expo-asset';
export class CategoryItem extends Component {
render = () => {
const styles = StyleSheet.create({
container: {
flex: 1,
},
item: {
backgroundColor: '#c2e3ff',
padding: 10,
height: 5,
marginVertical: 4,
marginHorizontal: 6,
},
title: {
fontSize: 6,
},
thumbnail: {
width: 50,
height: 50,
}
})
const {onPress, category} = this.props;
let img;
if(category.image != null) img = category.image;
else img = '../assets/images/noimage.png';
const [ setReady ] = useState();
const [image, setImage] = useState([]);
useEffect(() => {
(async () => {
const image = Asset.fromModule(img);
await image.downloadAsync();
setImage(image);
setReady(true);
})();
}, []);
return (
<TouchableOpacity onPress={onPress}>
<View style={styles.item}>
<Text>{category.title}</Text>
<Image style={styles.thumbnail} source={{ uri: image.localUri || image.uri }} />
</View>
</TouchableOpacity>
);
};
}
import React, {Component, useState, useEffect} from 'react';
import {StyleSheet, TouchableOpacity, Image, Text, View} from 'react-native';
import { Asset } from 'expo-asset';
export class CardItem extends Component {
render = () => {
const {onPress, card} = this.props;
let img;
const styles = StyleSheet.create({
container: {
flex: 1,
},
item: {
backgroundColor: '#c2e3ff',
padding: 20,
height: 10,
marginVertical: 8,
marginHorizontal: 16,
},
title: {
fontSize: 12,
},
thumbnail: {
width: 100,
height: 100,
}
})
if(card.image != null) img = card.image;
else img = '../assets/images/noimage.png';
const [ setReady ] = useState();
const [image, setImage] = useState([]);
useEffect(() => {
(async () => {
const image = Asset.fromModule(img);
await image.downloadAsync();
setImage(image);
setReady(true);
})();
}, []);
return (
<TouchableOpacity onPress={onPress}>
<View style={styles.item}>
<Text>{card.title}</Text>
<Image style={styles.thumbnail} source={{ uri: image.localUri || image.uri }} />
</View>
</TouchableOpacity>
);
};
}
export class ListFeed extends Component {
constructor(props){
let service = props.svc,
filter = props.flt,
result = null,
response = null;
switch (service) {
case "cards":
if(filter != null){
let pms = [
filter == "start" ? true : false,
filter == "last" ? true : false,
filter == "best" ? true : false
];
if (pms[2]) result = listData[0];
if (pms[0]) result = listData[2];
if (pms[1]) result = listData[1];
response = ({ image, title }) => {
<Container col style={dataGrid[0].card}>
<Image style={dataGrid[1].card} source={{uri: image}} />
<Text h3 style={dataGrid[2].card}>{title}</Text>
</Container>
}
}
else{
let count = 2;
for (let index = 0; index < count; index++) {
result += listData[index];
response += ({ title }) => {
<Container col style={dataGrid[0].card}>
<Text h3 style={dataGrid[1].card}>{title}</Text>
</Container>
}
}
}
break;
}
this.result = result;
this.response = response;
}
render = () => {
return (
<FlatList data={this.result} renderItem={this.response} />
)
}
}
export class FeedData extends Component {
constructor(props){
let service = props.svc,
filter = props.flt,
result = null,
response = null;
switch (service) {
case "cards":
if(filter != null){
let pms = [
filter == "start" ? true : false,
filter == "last" ? true : false,
filter == "best" ? true : false
];
if (pms[2]) result = cardsData[0];
if (pms[0]) result = cardsData[2];
if (pms[1]) result = cardsData[1];
response = ({ image, title }) => {
<Container col style={dataGrid[0].card}>
<Image style={dataGrid[1].card} source={{uri: image}} />
<Text h3 style={dataGrid[2].card}>{title}</Text>
</Container>
}
}
else{
result = cardsData[0];
response = ({ image, title }) => {
<Container col style={dataGrid[0].card}>
<Image style={dataGrid[1].card} source={{uri: image}} />
<Text h3 style={dataGrid[2].card}>{title}</Text>
</Container>
}
}
break;
}
this.result = result;
this.response = response;
}
render = () => {
return (
<FlatList data={this.result} renderItem={this.response} />
)
}
}
if($_POST['phone']) {
и if($_REQUEST['phone']) {
var_dump($_POST)
после отправки POST-запроса:array(0) {}
const RangeInput = () => {
var rangetext = [
$('.objects-adding-search > footer #left-content .input-from-to:nth-child(1) .content-form input#from'),
$('.objects-adding-search > footer #left-content .input-from-to:nth-child(1) .content-form input#to')
];
var rangeeventext = [
$('.objects-adding-search > footer #left-content .input-from-to:nth-child(2) .content-form input#from'),
$('.objects-adding-search > footer #left-content .input-from-to:nth-child(2) .content-form input#to')
];
var range = [
$('.objects-adding-search > footer #right-content .range-form:nth-child(1) input[type="range"]#min'),
$('.objects-adding-search > footer #right-content .range-form:nth-child(1) input[type="range"]#max')
];
var evenrange = [
$('.objects-adding-search > footer #right-content .range-form:nth-child(2) input[type="range"]#min'),
$('.objects-adding-search > footer #right-content .range-form:nth-child(2) input[type="range"]#max')
];
for (let i = 0; i < range.length; i++) {
const a = range[i],
b = evenrange[i],
d = rangeeventext[i];
a.bind('input', function (e) {
var val = $(this).val();
var curmax = rangetext[i];
var query;
query = val + " m2";
curmax.val(query);
});
b.bind('input', function (e) {
var val = $(this).val();
var curmax = d;
var query;
query = val;
curmax.val(query);
});
}
for (let i = 0; i < range.length; i++) {
rangetext[i].bind('input change', function (e,t) {
const v = $(this).val(),
r = range[i];
let rangeFigure;
if (v.indexOf(" m2") != -1) { rangeFigure = parseInt(v.slice(0,-3)); }
else { rangeFigure = parseInt(v); }
r.val(rangeFigure);
$(this).val(rangeFigure + ' m2');
});
}
for (let i = 0; i < evenrange.length; i++) {
rangeeventext[i].bind('input change', function (e,t) {
const v = $(this).val(),
r = evenrange[i];
r.val(parseInt(v));
});
}
}
$(document).ready(function () {
RangeInput();
});
Такие блоки как#news
, имеют абсолютное позиционирование, а шапка с контентом внутри них - относительное. Вышло так, когда я распологал правильно надписи, над футером и под контентом вышла белая полоса, которую очень трудно исправить...
<div class="promoblock swiper-slide">
<div class="promoblock_content" style="background-color:white;">
<header>
<a href=""><strong>Factorys</strong>(92)</a>
</header>
<main>
<span class="location">
Austria
</span>
<img src="https://lyubimiigorod.ru/web/v2assets/img/noImg_2-1.jpg" alt="Not image">
</main>
<footer>
<div class="info">
<span>Austria, a plant for the production of sausages...</span>
<span> </span>
<span>$ 10 300 000</span>
</div>
<div class="raiting">
<span>Expert Raiting</span>
<div class="rating-mini">
<span class="active"></span>
<span class="active"></span>
<span class="active"></span>
<span class="active"></span>
<span class="active"></span>
<span class="active"></span>
<span class="active"></span>
<span></span>
<span></span>
<span></span>
</div>
</div>
</footer>
</div>
</div>