Форум программистов, компьютерный форум, киберфорум
Наши страницы
Anna5194
Войти
Регистрация
Восстановить пароль
Оценить эту запись

Градиент

Запись от Anna5194 размещена 29.05.2019 в 13:35

Долго мучилась с градиентом и ангуляром, который не хотел видеть мой элемент. В итоге мне помогли найти решение. Боже, спасибо всем тем мидлам, что мне помогают. Ромочка, ты - лучший!

HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
<div class="home-developer">
  <div class='gradient' id="gradient" #gradient>
      <!-- [className]="!isShowMoreCompanies ? 'not' : 'present'" -->
  <div class="grid" #content>
    <div class="home-info__item col--xlg-1-2 col--lg-1-2 col--md-1-2 col--sm-1-2 col--xs-1-1"
      *ngFor='let item of arrayList | slice:0:countCompany'>
      <div class="home-developer__logo">
        <img src="{{item.logo}}" alt="#">
      </div>
      <div class="home-developer__title">{{item.title}}</div>
      <p class="home-developer__rc">{{item.rc}}
        <span class="home-developer__price">{{item.price}}</span>
      </p>
      <br>
      <p class="home-developer__apart">{{item.apartments}}</p>
    </div>
 
    <div class="col--1-1">
      <!-- <div class="home-developer__more home-developer__margin-block"> -->
      <div class="home-developer__more" id="buttonSwitch">
        <button class="home-developer__more-btn btn btn--yellow"
          (click)="showMore()">
          {{ isShowMoreCompanies ? 'Скрыть' : 'Показать ещё'}}
        </button>
      </div>
    </div>
  </div>
  </div>
  <!-- <div class="gradient" #gradient id="gradient"></div> -->
</div>
Javascript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
import { Component, ElementRef, OnInit, HostListener, Directive, Renderer2, ViewChild } from '@angular/core';
 
 
@Component({
    selector: 'data-developer-block-card',
    templateUrl: './developer-block-card.html',
    styleUrls: ['./developer-block-card.less']
})
 
 
export class DeveloperBlockCard implements OnInit{
  // @ViewChild('content') Component :ElementRef;
  @ViewChild('gradient') gradientEl :ElementRef;
 
  // renderer: any;
  DoCheck;
  content: ElementRef;
  // gradient: ElementRef;
  showContent: ElementRef;
  numberOfClicks = 0;
  isShowMoreCompanies: boolean = false;
  isShowMore: boolean = true;
  button: ElementRef;
 
  arrayList: any = [
    {
      logo: "https://data2.logaster.com/logotype/data/5410523/png/512/1/?c=b03e679a8687b207dbec72112b999b3e",
      title: "ПИК",
      rc: "28 ЖК",
      price: "от 3,1 млн",
      apartments: "6 988 квартир",
    },
    {
      logo: "https://data1.logaster.com/logotype/data/5413158/png/512/1/?c=421366bd831202f9ce00d973cfed6ba3",
      title: "MR GROUP",
      rc: "13 ЖК",
      price: "от 5,9 млн",
      apartments: "3 067 кварти", 
    },
    // {
    //   logo: "https://data2.logaster.com/logotype/data/5410523/png/512/1/?c=b03e679a8687b207dbec72112b999b3e",
    //   title: "Главстрой",
    //   rc: "1 ЖК",
    //   price: "от 3,8 млн",
    //   apartments: "1 266 квартир",
    // },
    // {
    //   logo: "https://data2.logaster.com/logotype/data/5410523/png/512/1/?c=b03e679a8687b207dbec72112b999b3e",
    //   title: "ПИК",
    //   rc: "28 ЖК",
    //   price: "от 3,1 млн",
    //   apartments: "6 988 квартир",
    // },
    // {
    //   logo: "https://data1.logaster.com/logotype/data/5413158/png/512/1/?c=421366bd831202f9ce00d973cfed6ba3",
    //   title: "MR GROUP",
    //   rc: "13 ЖК",
    //   price: "от 5,9 млн",
    //   apartments: "3 067 кварти", 
    // },
    // {
    //   logo: "https://data2.logaster.com/logotype/data/5410523/png/512/1/?c=b03e679a8687b207dbec72112b999b3e",
    //   title: "Главстрой",
    //   rc: "1 ЖК",
    //   price: "от 3,8 млн",
    //   apartments: "1 266 квартир",
    // },
    // {
    //   logo: "https://data2.logaster.com/logotype/data/5410523/png/512/1/?c=b03e679a8687b207dbec72112b999b3e",
    //   title: "ПИК",
    //   rc: "28 ЖК",
    //   price: "от 3,1 млн",
    //   apartments: "6 988 квартир",
    // },
    // {
    //   logo: "https://data1.logaster.com/logotype/data/5413158/png/512/1/?c=421366bd831202f9ce00d973cfed6ba3",
    //   title: "MR GROUP",
    //   rc: "13 ЖК",
    //   price: "от 5,9 млн",
    //   apartments: "3 067 кварти", 
    // },
    // {
    //   logo: "https://data2.logaster.com/logotype/data/5410523/png/512/1/?c=b03e679a8687b207dbec72112b999b3e",
    //   title: "Главстрой",
    //   rc: "1 ЖК",
    //   price: "от 3,8 млн",
    //   apartments: "1 266 квартир",
    // },
    // {
    //   logo: "https://data2.logaster.com/logotype/data/5410523/png/512/1/?c=b03e679a8687b207dbec72112b999b3e",
    //   title: "ПИК",
    //   rc: "28 ЖК",
    //   price: "от 3,1 млн",
    //   apartments: "6 988 квартир",
    // }
  ];
 
  arrayListOne: any = [
    {
      logo: "https://data2.logaster.com/logotype/data/5410523/png/512/1/?c=b03e679a8687b207dbec72112b999b3e",
      title: "ПИК",
      rc: "28 ЖК",
      price: "от 3,1 млн",
      apartments: "6 988 квартир",
    },
    {
      logo: "https://data1.logaster.com/logotype/data/5413158/png/512/1/?c=421366bd831202f9ce00d973cfed6ba3",
      title: "MR GROUP",
      rc: "13 ЖК",
      price: "от 5,9 млн",
      apartments: "3 067 кварти", 
    },
    {
      logo: "https://data2.logaster.com/logotype/data/5410523/png/512/1/?c=b03e679a8687b207dbec72112b999b3e",
      title: "Главстрой",
      rc: "1 ЖК",
      price: "от 3,8 млн",
      apartments: "1 266 квартир",
    },
  ]
  countCompany: number;
  
  constructor(
    private renderer: Renderer2,
    private elementRef: ElementRef
    ){}
 
  ngOnInit(): void {
    let button = document.getElementById('buttonSwitch');
    let gradient = document.getElementById('gradient');
 
    if(this.arrayList.length > 4){
      this.countCompany = 4;
    }
    else{
      this.countCompany = this.arrayList.length;
      this.renderer.addClass(this.gradientEl.nativeElement, 'not');
      // button.style.display = 'none';
      // gradient.className = 'not';
    }
  }
 
  showMore(){
    let gradient = document.getElementById('gradient');
    let content = document.getElementById('content');
 
    if(!this.isShowMoreCompanies){
      this.countCompany = this.arrayList.length;
      this.renderer.addClass(this.gradientEl.nativeElement, 'not');
      // content.style.backgroundColor = "blue";
      // gradient.style.content = 'none';
      // gradient.addClass('not');
      // gradient.className = "gradientPresent";
    }
    else{
      this.countCompany = 4;
      this.renderer.removeClass(this.gradientEl.nativeElement, 'not');
      // content.style.backgroundColor = "red";
      // gradient.style.className = 'present';   
    }
 
    this.isShowMoreCompanies = !this.isShowMoreCompanies;
   
  }
  
 
  showMoreCompanies(){
    this.isShowMoreCompanies = !this.isShowMoreCompanies;
    console.log(this.isShowMoreCompanies);
    let content = document.getElementById('content');
    let gradient = document.getElementById('gradient');
    let button = document.getElementById('buttonDown');
 
    if(this.isShowMoreCompanies){
      // content.style.height = '300px';
      // gradient.style.display = 'block';
      // button.style.bottom = '1315px';
      // this.renderer.nativeElement.addClass(content, 'active');
      
    }
    else{
      // content.style.height = '100%';
      // gradient.style.display = 'none';
      // button.style.bottom = '1315px';
      // this.renderer.nativeElement.removeClass(content, 'active');
      
    }
  }
  
  ngDoCheck(): void {
    //Called every time that the input properties of a component or a directive are checked. Use it to extend change detection by performing a custom check.
    //Add 'implements DoCheck' to the class.
    
  }
 
  // @HostListener("click") onClick(){
  //   this.isShowMoreCompanies = !this.isShowMoreCompanies;
  //   if(this.isShowMoreCompanies){
  //     console.log("lalalend");
  //   }
  //   else{
  //     console.log('nani');
  //   }
  // }
  
}
CSS
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
.home-developer.active{
    overflow: hidden;
}
 
// .home-developer__parent{
//     position: relative;
//     // display: flex;
//     // flex-wrap: wrap;
// }
 
// .home-developer.panel.m--t{
//     background: linear-gradient(to bottom, rgba(255, 0, 0, 0.8) 0%, rgba(0, 0, 0, 0.1) 100%);
// }
 
.home-developer{
    // background: linear-gradient(to bottom, rgb(223, 12, 12) 0%,rgba(255,255,255,0) 100%);
    height: 100px;;
    width: 100%;
    display: inline;
    flex-wrap: wrap;
    // margin-right: 0;
    // grid-template-columns: repeat(5, 100%);
    // grid-auto-rows: 50px;
    overflow: hidden;
 
    // .home-info__item{
    //     z-index: 1;
    // }
    .grid{
        overflow: hidden;
        height: 100%;
    }
    .gradient{
        display: block;
        width:100%;
        margin:20px auto;
        cursor:text;
        // box-shadow:inset 0px -190px 190px -50px #add7f8;
        // max-height:100px;
        overflow:hidden;
        // background-image:linear-gradient(to bottom, transparent, red 100%);
        z-index: 2;
        // margin-top:-20px;
 
        &::after{
            content:"";
            display:block;
            height:50px;
            position:relative;
            bottom:110px;
            background-image:linear-gradient(to bottom, transparent, white 100%);
        }
            
    }
 
    .gradient.not{
        &::after{
        background-image:linear-gradient(to bottom, transparent, transparent 100%);
    }
    }
    
    // .gradientPresent{
    //     &::after{
    //     background-image:linear-gradient(to bottom, transparent, green 100%);
    // }
    // }
    
 
    .home-info__item{
        padding-top: 15px;
        padding-bottom: 15px;
        height: 75px;
        border-bottom: 1px solid grey;
    }
 
    & &__logo{
        // grid-column-start: 1;
        // grid-column-end: 1;
        // grid-row-start: 1;
        // grid-row-end: 3;
        float: left;
        width: 45px;
        height: 45px;
        background-color: aquamarine;
        background: no-repeat center center;
        border: 1px solid grey;
        vertical-align: middle;
        margin-right: 30px;
        font-weight: 900;
        
    }
 
    & &__title{
        // grid-column-start: 2;
        // grid-column-end: 4;
        // grid-row-start: 1;
        // grid-row-end: 3;
        float: left;
        margin-top: 15px;
        vertical-align: middle;
        font-weight: 900;
 
    }
 
    & &__rc{
        // grid-column-start: 4;
        // grid-column-end: 4;
        // grid-row-start: 1;
        // grid-row-end: 2;
        float: right;
        top: 0;
        color: aquamarine;
 
    }
 
    & &__price{
        // grid-column-start: 5;
        // grid-column-end: 5;
        // grid-row-start: 2;
        // grid-row-end: 3;
        color: black;
        float: right;
        top: 0;
        margin-left: 20px;
 
    }
 
    & &__apart{
        // margin-top: 30px;
        // grid-column-start: 4;
        // grid-column-end: 4;
        // grid-row-start: 3;
        // grid-row-end: 3;
        float: right;
        // width: 20%;
        margin-top: 10px;
        // margin-right: -100px;
        // margin-bottom: 30px;
        right: 0;
        bottom: 0;
        color: grey;
        text-align: right;
        vertical-align: bottom;
 
    }
 
    // & &__parent{
    //     padding-top: 15px;
    //     padding-bottom: 15px;
    //     height: 75px;
    //     border-bottom: 1px solid grey;
    // }
 
    // & &__margin-block{
    //     margin-top: 50px;
    // }
 
    & &__more{
        position: relative;
        margin-top: 20px;
        text-align: center;
 
        &-btn{
            min-width: 200px;
        }
    }
    
    // & &__button{
    //     cursor: pointer;
    //     bottom: 0;
    //     left: 0;
    //     position: absolute;
    //     height: 40px;
    //     width: 150px;
    //     background-color: gold;
    //     border-radius: 5px;
    //     color: grey;
    //     font-weight: 700;
    //     margin-top: 5px;
    //     z-index: 10;
    //     margin-left: 20px;
    //     margin-bottom: 20px;
    // }
}
Размещено в Без категории
Просмотров 103 Комментарии 0
Всего комментариев 0
Комментарии
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2019, vBulletin Solutions, Inc.
Рейтинг@Mail.ru