├── .gitignore
├── client
├── states
│ ├── search
│ │ ├── value.js
│ │ ├── huya
│ │ │ ├── value.js
│ │ │ ├── route.js
│ │ │ ├── template.html
│ │ │ └── style.less
│ │ ├── bili
│ │ │ ├── value.js
│ │ │ ├── route.js
│ │ │ ├── template.html
│ │ │ └── style.less
│ │ ├── douyu
│ │ │ ├── value.js
│ │ │ ├── route.js
│ │ │ ├── template.html
│ │ │ └── style.less
│ │ ├── zhanqi
│ │ │ ├── value.js
│ │ │ ├── route.js
│ │ │ ├── template.html
│ │ │ └── style.less
│ │ ├── panda
│ │ │ ├── value.js
│ │ │ ├── route.js
│ │ │ ├── template.html
│ │ │ └── style.less
│ │ ├── route.js
│ │ ├── style.less
│ │ └── template.html
│ ├── video
│ │ ├── value.js
│ │ ├── template.html
│ │ ├── style.less
│ │ └── route.js
│ └── index
│ │ ├── value.js
│ │ ├── template.html
│ │ ├── style.less
│ │ └── route.js
├── service
│ ├── biliService.js
│ ├── huyaService.js
│ ├── douyuService.js
│ ├── pandaService.js
│ └── zhanqiService.js
├── main.less
├── main.html
├── main.js
└── lib
│ └── cm-plugin.js
├── public
├── img
│ └── bili-logo-s.png
├── liveSearch
│ ├── styles.3810b05e.css.map
│ ├── layout.html
│ └── styles.3810b05e.css
├── package.json
└── main.js
├── env.js
├── README.md
├── package.json
├── LICENSE.md
├── webpack.base.config.js
└── webpack.prod.config.js
/.gitignore:
--------------------------------------------------------------------------------
1 | .idea/
2 | node_modules
3 |
--------------------------------------------------------------------------------
/client/states/search/value.js:
--------------------------------------------------------------------------------
1 | const value = {
2 |
3 | }
4 |
5 | export default value;
--------------------------------------------------------------------------------
/client/states/video/value.js:
--------------------------------------------------------------------------------
1 | const value = {
2 |
3 | url : ''
4 | }
5 |
6 | export default value;
--------------------------------------------------------------------------------
/client/states/index/value.js:
--------------------------------------------------------------------------------
1 | const value = {
2 |
3 | keyword : ''
4 | }
5 |
6 | export default value;
--------------------------------------------------------------------------------
/public/img/bili-logo-s.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/yjj5855/electron-vue/master/public/img/bili-logo-s.png
--------------------------------------------------------------------------------
/public/liveSearch/styles.3810b05e.css.map:
--------------------------------------------------------------------------------
1 | {"version":3,"sources":[],"names":[],"mappings":"","file":"styles.3810b05e.css","sourceRoot":""}
--------------------------------------------------------------------------------
/public/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "liveSearch",
3 | "version": "0.1.0",
4 | "main": "main.js",
5 | "scripts": {
6 |
7 | },
8 | "dependencies": {
9 |
10 | }
11 | }
12 |
--------------------------------------------------------------------------------
/client/states/search/huya/value.js:
--------------------------------------------------------------------------------
1 | const value = {
2 |
3 | huyaList : {
4 | items : [],
5 | total : 0
6 | },
7 | page : 1,
8 |
9 | showAnimation : true,
10 | stagger : 100,
11 | }
12 |
13 | export default value;
--------------------------------------------------------------------------------
/client/states/search/bili/value.js:
--------------------------------------------------------------------------------
1 | const value = {
2 | isliving : true,
3 | biliList : {
4 | items : [],
5 | total : 0
6 | },
7 | page : 1,
8 |
9 | showAnimation : true,
10 | stagger : 100,
11 | }
12 |
13 | export default value;
--------------------------------------------------------------------------------
/client/states/search/douyu/value.js:
--------------------------------------------------------------------------------
1 | const value = {
2 | isliving : true,
3 | douyuList : {
4 | items : [],
5 | total : 0
6 | },
7 | page : 1,
8 |
9 | showAnimation : true,
10 | stagger : 100,
11 | }
12 |
13 | export default value;
--------------------------------------------------------------------------------
/client/states/search/zhanqi/value.js:
--------------------------------------------------------------------------------
1 | const value = {
2 | isliving : true,
3 | zhanqiList : {
4 | items : [],
5 | total : 0
6 | },
7 | page : 1,
8 |
9 | showAnimation : true,
10 | stagger : 100,
11 | }
12 |
13 | export default value;
--------------------------------------------------------------------------------
/client/states/search/panda/value.js:
--------------------------------------------------------------------------------
1 | const value = {
2 | date : new Date().Format('yyyy-MM-dd'),
3 | pandaList : {
4 | items : [],
5 | total : 0
6 | },
7 | page : 1,
8 |
9 | showAnimation : true,
10 | stagger : 100,
11 | }
12 |
13 | export default value;
--------------------------------------------------------------------------------
/client/states/video/template.html:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/env.js:
--------------------------------------------------------------------------------
1 | 'use strict';
2 | const env = {
3 | NODE_ENV : 'test',
4 | PORT : '5669',
5 | host_panda : 'http://www.panda.tv',
6 | host_huya : 'http://search.huya.com',
7 | host_douyu : 'http://www.douyu.com',
8 | host_bili : 'http://live.bilibili.com',
9 | host_zhanqi : 'http://www.zhanqi.tv',
10 |
11 | host_self : 'http://yangjj.me:5669',
12 | }
13 | export default env;
--------------------------------------------------------------------------------
/client/states/video/style.less:
--------------------------------------------------------------------------------
1 | .page.video{
2 | .bar.bar-nav{
3 | top: .5rem;
4 | background: transparent;
5 | &:after {
6 | -webkit-transform: scaleY(0);
7 | transform: scaleY(0);
8 | }
9 |
10 | .icon.icon-left{
11 | width: 2.2rem;
12 | height: 2.2rem;
13 | text-align: center;
14 | color: #fff;
15 | background: rgba(0,0,0,.5);
16 | border-radius: 50%;
17 | }
18 | }
19 | iframe{
20 | border: 0;
21 | }
22 | }
--------------------------------------------------------------------------------
/client/service/biliService.js:
--------------------------------------------------------------------------------
1 | import env from '../../env'
2 | //异步函数
3 | export async function searchLiveRoom(keyword,page){
4 |
5 | return new Promise((success,error)=>{
6 | $.ajax({
7 | type : 'GET',
8 | url : env.host_self+'/bili/'+keyword+'?page='+page,
9 | success : function(response){
10 | success(response)
11 | },
12 | error : function(xhr){
13 | error('请求失败')
14 | }
15 | });
16 | })
17 | }
--------------------------------------------------------------------------------
/client/service/huyaService.js:
--------------------------------------------------------------------------------
1 | import env from '../../env'
2 | //异步函数
3 | export async function searchLiveRoom(keyword,page){
4 |
5 | return new Promise((success,error)=>{
6 | $.ajax({
7 | type : 'GET',
8 | url : env.host_self+'/huya/'+keyword+'?page='+page,
9 | success : function(response){
10 | success(response)
11 | },
12 | error : function(xhr){
13 | error('请求失败')
14 | }
15 | });
16 | })
17 | }
--------------------------------------------------------------------------------
/client/service/douyuService.js:
--------------------------------------------------------------------------------
1 | import env from '../../env'
2 | //异步函数
3 | export async function searchLiveRoom(keyword,page){
4 |
5 | return new Promise((success,error)=>{
6 | $.ajax({
7 | type : 'GET',
8 | url : env.host_self+'/douyu/'+keyword+'?page='+page,
9 | success : function(response){
10 | success(response)
11 | },
12 | error : function(xhr){
13 | error('请求失败')
14 | }
15 | });
16 | })
17 | }
--------------------------------------------------------------------------------
/client/service/pandaService.js:
--------------------------------------------------------------------------------
1 | import env from '../../env'
2 | //异步函数
3 | export async function searchLiveRoom(keyword,page){
4 |
5 | return new Promise((success,error)=>{
6 | $.ajax({
7 | type : 'GET',
8 | url : env.host_self+'/panda/'+keyword+'?page='+page,
9 | success : function(response){
10 | success(response)
11 | },
12 | error : function(xhr){
13 | error('请求失败')
14 | }
15 | });
16 | })
17 | }
--------------------------------------------------------------------------------
/client/service/zhanqiService.js:
--------------------------------------------------------------------------------
1 | import env from '../../env'
2 | //异步函数
3 | export async function searchLiveRoom(keyword,page){
4 |
5 | return new Promise((success,error)=>{
6 | $.ajax({
7 | type : 'GET',
8 | url : env.host_self+'/zhanqi/'+keyword+'?page='+page,
9 | success : function(response){
10 | success(response)
11 | },
12 | error : function(xhr){
13 | error('请求失败')
14 | }
15 | });
16 | })
17 | }
--------------------------------------------------------------------------------
/client/main.less:
--------------------------------------------------------------------------------
1 | .video-box-transition{
2 | transition: all .5s ease;
3 | -webkit-animation:bounceIn 1s .2s ease both;
4 | -moz-animation:bounceIn 1s .2s ease both;
5 | }
6 | .video-box-enter,.video-box-leave{
7 |
8 | }
9 |
10 | @-webkit-keyframes bounceIn{
11 | 0%{opacity:0;
12 | -webkit-transform:scale(.3)}
13 | 50%{opacity:1;
14 | -webkit-transform:scale(1.05)}
15 | 70%{-webkit-transform:scale(.9)}
16 | 100%{-webkit-transform:scale(1)}
17 | }
18 | @-moz-keyframes bounceIn{
19 | 0%{opacity:0;
20 | -moz-transform:scale(.3)}
21 | 50%{opacity:1;
22 | -moz-transform:scale(1.05)}
23 | 70%{-moz-transform:scale(.9)}
24 | 100%{-moz-transform:scale(1)}
25 | }
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
1 | electron 练手项目 纯前端 配合vue框架做的
2 | 这个项目本来是一个webapp
3 |
4 | client 是客户端 源码文件夹
5 | public 是最终要打成asar文件的目录
6 |
7 | 使用webpack打包client中的源码,到public/liveSearch中
8 |
9 | #开发流程
10 |
11 | ###1.需全局安装
12 | ```
13 | npm install electron-prebuilt -g
14 | npm install asar -g
15 | npm install webpack -g
16 | ```
17 |
18 | ###2.webpack打包
19 | ```
20 | npm run build
21 | ```
22 |
23 | ###3.开发时运行
24 | ```
25 | npm run dev
26 | ```
27 |
28 | ###4.打包成asar文件
29 | ```
30 | npm run asar
31 | ```
32 |
33 | ###5.转成各平台对应的app
34 |
35 | ####简单打包
36 | 去[官网](https://github.com/electron/electron/releases)下载各平台对应的压缩包,解压出来,
37 | 把default_app.asar替换成上一步打出来的asar文件
38 |
39 | ####自动化打包
40 | 使用[electron-packager](https://github.com/electron-userland/electron-packager)
--------------------------------------------------------------------------------
/client/states/search/route.js:
--------------------------------------------------------------------------------
1 | 'use strict';
2 | import Vue from 'vue'
3 | import Tpl from './template.html'
4 | import Value from './value'
5 | import './style.less'
6 |
7 | let Index = Vue.extend({
8 | //replace : true, //必须注释掉 不然动画失效
9 | template : Tpl,
10 | init : function () {
11 |
12 | },
13 | ready : function(){ //做浏览器判断 和 兼容
14 |
15 | //需要初始化一下,不然监听不到infinite事件
16 | $.init();
17 | },
18 | events : {
19 |
20 | },
21 | data : ()=>{
22 | return Value
23 | },
24 | methods: {
25 |
26 | },
27 | computed : {
28 |
29 | },
30 | route : {
31 | data : function(transition){
32 |
33 | }
34 | }
35 | })
36 |
37 | export default Index
--------------------------------------------------------------------------------
/client/states/video/route.js:
--------------------------------------------------------------------------------
1 | 'use strict';
2 | import Vue from 'vue'
3 | import Tpl from './template.html'
4 | import Value from './value'
5 | import './style.less'
6 | import {searchLiveRoom} from '../../service/pandaService'
7 |
8 | let Index = Vue.extend({
9 | //replace : true, //必须注释掉 不然动画失效
10 | template : Tpl,
11 | init : function () {
12 |
13 | },
14 | ready : function(){ //做浏览器判断 和 兼容
15 |
16 |
17 | $.init();
18 | },
19 | data : ()=>{
20 | return Value
21 | },
22 | methods: {
23 |
24 | },
25 | computed : {
26 |
27 | },
28 | route : {
29 | data : function(transition){
30 | this.url = decodeURIComponent(transition.to.query.url);
31 | console.log(this.url)
32 | }
33 | }
34 | })
35 |
36 | export default Index
--------------------------------------------------------------------------------
/client/states/index/template.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
7 |
8 |
9 |
12 |
13 |
14 |
--------------------------------------------------------------------------------
/client/main.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 | 直播搜索
7 |
8 |
9 |
10 |
11 |
12 |
13 |
14 |
15 |
16 |
17 |
18 |
19 |
20 |
21 |
22 |
25 |
26 |
32 |
33 |
34 |
35 |
--------------------------------------------------------------------------------
/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "liveSearch",
3 | "version": "0.1.0",
4 |
5 | "scripts": {
6 | "dev": "electron ./public",
7 | "build": "rm -rf ./public/liveSearch && webpack --progress --hide-modules --config webpack.prod.config.js",
8 | "asar": "rm -rf default_app.asar && asar pack ./public default_app.asar"
9 | },
10 | "dependencies": {
11 | "babel-cli": "^6.9.0",
12 | "babel-core": "^6.0.0",
13 | "babel-loader": "^6.0.0",
14 | "babel-preset-es2015": "^6.0.0",
15 | "babel-preset-stage-3": "^6.0.0",
16 | "css-loader": "^0.23.1",
17 | "eve": "^0.5.0",
18 | "extract-text-webpack-plugin": "^1.0.1",
19 | "html-webpack-plugin": "^2.8.2",
20 | "less": "^2.6.0",
21 | "less-loader": "^2.2.2",
22 | "platform": "^1.3.1",
23 | "postcss-loader": "^0.9.1",
24 | "precss": "^1.4.0",
25 | "raw-loader": "^0.5.1",
26 | "style-loader": "^0.13.0",
27 | "url-loader": "^0.5.7",
28 | "vue": "^1.0.24",
29 | "vue-router": "^0.7.10",
30 | "webpack": "^1.4.13"
31 | }
32 | }
33 |
--------------------------------------------------------------------------------
/LICENSE.md:
--------------------------------------------------------------------------------
1 | The MIT License (MIT)
2 |
3 | Copyright (c) 2016 yjj5855
4 |
5 | Permission is hereby granted, free of charge, to any person obtaining a copy
6 | of this software and associated documentation files (the "Software"), to deal
7 | in the Software without restriction, including without limitation the rights
8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9 | copies of the Software, and to permit persons to whom the Software is
10 | furnished to do so, subject to the following conditions:
11 |
12 | The above copyright notice and this permission notice shall be included in all
13 | copies or substantial portions of the Software.
14 |
15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21 | SOFTWARE.
22 |
--------------------------------------------------------------------------------
/public/liveSearch/layout.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 | 直播搜索
7 |
8 |
9 |
10 |
11 |
12 |
13 |
14 |
15 |
16 |
17 |
18 |
19 |
20 |
21 |
22 |
25 |
26 |
32 |
33 |
34 |
35 |
--------------------------------------------------------------------------------
/webpack.base.config.js:
--------------------------------------------------------------------------------
1 | var path = require('path')
2 | var webpack = require('webpack')
3 | var ExtractTextPlugin = require("extract-text-webpack-plugin");
4 | var precss = require('precss');
5 | var autoprefixer = require('autoprefixer');
6 |
7 |
8 | module.exports = {
9 |
10 | devtool: 'source-map',
11 |
12 | entry: {
13 | web_app:"./client/main",
14 | //公共库
15 | vendor : [
16 | 'babel-polyfill',
17 | './env',
18 | 'vue',
19 | 'vue-router',
20 | ]
21 | },
22 |
23 | output: {
24 | path: __dirname + '/public/liveSearch',
25 | filename: '[name].[chunkhash:8].js',
26 | chunkFilename: '[id].[chunkhash:8].js',
27 | publicPath: './'
28 | },
29 |
30 | module: {
31 | loaders: [
32 | { test: /\.js$/,
33 | exclude: /node_modules/,
34 | loader: 'babel' ,
35 | query: {
36 | cacheDirectory: true,
37 | presets: ['es2015','stage-3']
38 | }
39 | },
40 | { test: /\.html$/, loader: 'raw' },
41 | { test: /\.less$/, loader: ExtractTextPlugin.extract("style-loader", "css-loader!postcss-loader!less-loader") },
42 | { test: /\.png$/, loader: 'url' ,query: { mimetype: "image/png" } }
43 |
44 | ]
45 | },
46 | postcss: function () {
47 | return [precss, autoprefixer];
48 | }
49 | }
50 |
--------------------------------------------------------------------------------
/webpack.prod.config.js:
--------------------------------------------------------------------------------
1 | var webpack = require('webpack')
2 | var config = require('./webpack.base.config')
3 | var HtmlWebpackPlugin = require('html-webpack-plugin')
4 | var ExtractTextPlugin = require("extract-text-webpack-plugin");
5 |
6 | config.devtool = 'source-map'
7 |
8 | config.output.filename = '[name].[chunkhash:8].js'
9 | config.output.chunkFilename = '[id].[chunkhash:8].js'
10 |
11 |
12 | config.plugins = (config.plugins || []).concat([
13 | //把所有独立样式的CSS打包成一个style.css
14 | new ExtractTextPlugin("styles.[hash:8].css",{allChunks: true}),
15 | new webpack.optimize.CommonsChunkPlugin({
16 | name: "vendor",
17 |
18 | filename: "[name].[hash:8].js",
19 | // (Give the chunk a different name)
20 |
21 | minChunks: Infinity,
22 | // (with more entries, this ensures that no other module
23 | // goes into the vendor chunk)
24 | }),
25 | new webpack.optimize.UglifyJsPlugin({
26 | compressor: {
27 | warnings: false
28 | }
29 | }),
30 | new HtmlWebpackPlugin({
31 | name:'layout',
32 | template: './client/main.html',
33 | filename: 'layout.html',
34 | inject: 'body',
35 | chunks: ['vendor', 'web_app'],
36 | minify:{ //压缩HTML文件
37 | removeComments:true, //移除HTML中的注释
38 | collapseWhitespace:false //删除空白符与换行符
39 | }
40 | })
41 | ])
42 |
43 | module.exports = config
--------------------------------------------------------------------------------
/client/states/search/style.less:
--------------------------------------------------------------------------------
1 | .page.search{
2 | .bar.bar-nav{
3 | top: .5rem;
4 | background: transparent;
5 |
6 | &:after {
7 | -webkit-transform: scaleY(0);
8 | transform: scaleY(0);
9 | }
10 |
11 | .icon.icon-left{
12 | width: 2.2rem;
13 | height: 2.2rem;
14 | text-align: center;
15 | color: #000;
16 | background: rgba(255, 255, 255, 0.8);
17 | border-radius: 50%;
18 | }
19 | }
20 |
21 | .content{
22 | top: 0;
23 | }
24 | .tab-item{
25 | background-size: 80%;
26 | background-repeat: no-repeat;
27 | background-position: center;
28 | -webkit-filter: grayscale(100%);
29 | -moz-filter: grayscale(100%);
30 | filter: grayscale(100%);
31 |
32 | span{
33 | visibility: hidden;
34 | }
35 |
36 | &.panda{
37 | background-image: url("http://i5.pdim.gs/06b000f296eb5f4f2a16e9e012cfcf7e.png");
38 | }
39 | &.huya{
40 | background-image: url("http://a.dwstatic.com/huya/main/img/logo_index_new09_4217d25.png");
41 | }
42 | &.douyu{
43 | background-image: url("http://shark.douyucdn.cn/app/douyu/res/com/logo.png?20160303");
44 | }
45 | &.bili{
46 | background-image: url("../../../public/img/bili-logo-s.png");
47 | }
48 | &.zhanqi{
49 | background-image: url("http://dlstatic.cdn.zhanqi.tv/assets/web/static/i/logo-6.png");
50 | }
51 | &.active{
52 | -webkit-filter: grayscale(0);
53 | -moz-filter: grayscale(0);
54 | filter: grayscale(0);
55 | }
56 | }
57 |
58 | .bar.bar-tab{
59 | background-color: rgba(255,255,255,.9);
60 | }
61 |
62 | }
--------------------------------------------------------------------------------
/client/main.js:
--------------------------------------------------------------------------------
1 | 'use strict';
2 | import "babel-polyfill"
3 | import './main.less'
4 | import Vue from 'vue'
5 | import VueRouter from 'vue-router'
6 | import VueCm from './lib/cm-plugin'
7 |
8 | //懒加载路由 只有访问这个路由才会加载js
9 | Vue.use(VueRouter);
10 | Vue.use(VueCm);
11 |
12 | var router = new VueRouter({
13 | history: true, //html5模式 去掉锚点
14 | saveScrollPosition: true //记住页面的滚动位置 html5模式适用
15 | })
16 |
17 | //定义路由
18 | router.map({
19 | '/': {
20 | component: require('./states/index/route').default
21 | },
22 | '/search/:keyword': {
23 | component: require('./states/search/route').default,
24 | subRoutes: {
25 | '/': {
26 | component: require('./states/search/panda/route').default
27 | },
28 | '/panda': {
29 | component: require('./states/search/panda/route').default
30 | },
31 | '/huya': {
32 | component: require('./states/search/huya/route').default
33 | },
34 | '/douyu': {
35 | component: require('./states/search/douyu/route').default
36 | },
37 | '/bili': {
38 | component: require('./states/search/bili/route').default
39 | },
40 | '/zhanqi': {
41 | component: require('./states/search/zhanqi/route').default
42 | }
43 | }
44 | },
45 | '/video': {
46 | component: require('./states/video/route').default
47 | },
48 | })
49 | router.redirect({
50 | '*': '/'
51 | })
52 |
53 | var App = Vue.extend({})
54 |
55 | //启动APP
56 | router.start(App, '#app')
--------------------------------------------------------------------------------
/client/states/search/template.html:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/public/main.js:
--------------------------------------------------------------------------------
1 | const electron = require('electron');
2 | // Module to control application life.
3 | const {app} = electron;
4 | // Module to create native browser window.
5 | const {BrowserWindow} = electron;
6 |
7 | // Keep a global reference of the window object, if you don't, the window will
8 | // be closed automatically when the JavaScript object is garbage collected.
9 | let win;
10 |
11 | function createWindow() {
12 | // Create the browser window.
13 | win = new BrowserWindow({width: 414, height: 736});
14 |
15 | // and load the index.html of the app.
16 | win.loadURL(`file://${__dirname}/liveSearch/layout.html`);
17 |
18 | // Open the DevTools.
19 | // win.webContents.openDevTools();
20 |
21 | // Emitted when the window is closed.
22 | win.on('closed', () => {
23 | // Dereference the window object, usually you would store windows
24 | // in an array if your app supports multi windows, this is the time
25 | // when you should delete the corresponding element.
26 | win = null;
27 | });
28 | }
29 |
30 | // This method will be called when Electron has finished
31 | // initialization and is ready to create browser windows.
32 | // Some APIs can only be used after this event occurs.
33 | app.on('ready', createWindow);
34 |
35 | // Quit when all windows are closed.
36 | app.on('window-all-closed', () => {
37 | // On OS X it is common for applications and their menu bar
38 | // to stay active until the user quits explicitly with Cmd + Q
39 | if (process.platform !== 'darwin') {
40 | app.quit();
41 | }
42 | });
43 |
44 | app.on('activate', () => {
45 | // On OS X it's common to re-create a window in the app when the
46 | // dock icon is clicked and there are no other windows open.
47 | if (win === null) {
48 | createWindow();
49 | }
50 | });
51 |
52 | // In this file you can include the rest of your app's specific main process
53 | // code. You can also put them in separate files and require them here.
--------------------------------------------------------------------------------
/client/states/search/zhanqi/route.js:
--------------------------------------------------------------------------------
1 | 'use strict';
2 | import Vue from 'vue'
3 | import Tpl from './template.html'
4 | import Value from './value'
5 | import './style.less'
6 | import {searchLiveRoom} from '../../../service/zhanqiService'
7 |
8 | let Index = Vue.extend({
9 | //replace : true, //必须注释掉 不然动画失效
10 | template : Tpl,
11 | init : function () {
12 |
13 | },
14 | ready : function(){ //做浏览器判断 和 兼容
15 |
16 | //需要初始化一下,不然监听不到infinite事件
17 | $.init();
18 |
19 | },
20 | data : ()=>{
21 | return Value
22 | },
23 | methods: {
24 | async loadList(){
25 | try{
26 | let keyword = this.$route.params.keyword;
27 | let data = await searchLiveRoom(keyword,this.page);
28 | if(data && data.status == 200){
29 | this.page += 1;
30 | this.zhanqiList.total = data.total;
31 | setTimeout(()=>{
32 | this.showAnimation = false;
33 | },data.items.length * this.stagger)
34 | this.showAnimation = true;
35 | for(let i=0;i{
21 | return Value
22 | },
23 | methods: {
24 | async loadList(){
25 | try{
26 | let keyword = this.$route.params.keyword;
27 | let data = await searchLiveRoom(keyword,this.page);
28 | if(data && data.status == 200){
29 | this.page += 1;
30 | this.biliList.total = data.total;
31 | setTimeout(()=>{
32 | this.showAnimation = false;
33 | },data.items.length * this.stagger)
34 | this.showAnimation = true;
35 | for(let i=0;i= parseInt(this.biliList.total);
47 | }
48 | },
49 | route : {
50 | data : function(transition){
51 | let keyword = transition.to.params.keyword;
52 | this.loadList();
53 | },
54 | deactivate : function (transition) {
55 | this.biliList = {
56 | items : [],
57 | total : 0
58 | };
59 | this.page = 1;
60 | transition.next();
61 | }
62 | }
63 | })
64 |
65 | export default Index
--------------------------------------------------------------------------------
/client/states/search/douyu/route.js:
--------------------------------------------------------------------------------
1 | 'use strict';
2 | import Vue from 'vue'
3 | import Tpl from './template.html'
4 | import Value from './value'
5 | import './style.less'
6 | import {searchLiveRoom} from '../../../service/douyuService'
7 |
8 | let Index = Vue.extend({
9 | //replace : true, //必须注释掉 不然动画失效
10 | template : Tpl,
11 | init : function () {
12 |
13 | },
14 | ready : function(){ //做浏览器判断 和 兼容
15 |
16 | //需要初始化一下,不然监听不到infinite事件
17 | $.init();
18 |
19 | },
20 | data : ()=>{
21 | return Value
22 | },
23 | methods: {
24 | async loadList(){
25 | try{
26 | let keyword = this.$route.params.keyword;
27 | let data = await searchLiveRoom(keyword,this.page);
28 | if(data && data.status == 200){
29 | this.page += 1;
30 | this.douyuList.total = data.total;
31 | setTimeout(()=>{
32 | this.showAnimation = false;
33 | },data.items.length * this.stagger)
34 | this.showAnimation = true;
35 | for(let i=0;i= parseInt(this.douyuList.total);
47 | }
48 | },
49 | route : {
50 | data : function(transition){
51 | let keyword = transition.to.params.keyword;
52 | this.loadList();
53 | },
54 | deactivate : function (transition) {
55 | this.douyuList = {
56 | items : [],
57 | total : 0
58 | };
59 | this.page = 1;
60 | transition.next();
61 | }
62 | }
63 | })
64 |
65 | export default Index
--------------------------------------------------------------------------------
/client/states/search/panda/route.js:
--------------------------------------------------------------------------------
1 | 'use strict';
2 | import Vue from 'vue'
3 | import Tpl from './template.html'
4 | import Value from './value'
5 | import './style.less'
6 | import {searchLiveRoom} from '../../../service/pandaService'
7 |
8 | let Index = Vue.extend({
9 | //replace : true, //必须注释掉 不然动画失效
10 | template : Tpl,
11 | init : function () {
12 |
13 | },
14 | ready : function(){ //做浏览器判断 和 兼容
15 |
16 | //需要初始化一下,不然监听不到infinite事件
17 | $.init();
18 |
19 | },
20 | data : ()=>{
21 | return Value
22 | },
23 | methods: {
24 | async loadList(){
25 | try{
26 | let keyword = this.$route.params.keyword;
27 | let data = await searchLiveRoom(keyword,this.page);
28 | if(data && data.errno == 0){
29 | this.pandaList.total = data.data.total;
30 | setTimeout(()=>{
31 | this.showAnimation = false;
32 | },data.data.items.length * this.stagger)
33 | this.showAnimation = true;
34 | for(let i=0;i= parseInt(this.pandaList.total);
47 | }
48 | },
49 | route : {
50 | data : function(transition){
51 | let keyword = transition.to.params.keyword;
52 | this.loadList();
53 | },
54 | deactivate : function (transition) {
55 | this.pandaList = {
56 | items : [],
57 | total : 0
58 | };
59 | this.page = 1;
60 | transition.next();
61 | }
62 | }
63 | })
64 |
65 | export default Index
--------------------------------------------------------------------------------
/client/states/search/huya/route.js:
--------------------------------------------------------------------------------
1 | 'use strict';
2 | import Vue from 'vue'
3 | import Tpl from './template.html'
4 | import Value from './value'
5 | import './style.less'
6 | import {searchLiveRoom} from '../../../service/huyaService'
7 |
8 | let Index = Vue.extend({
9 | //replace : true, //必须注释掉 不然动画失效
10 | template : Tpl,
11 | init : function () {
12 |
13 | },
14 | ready : function(){ //做浏览器判断 和 兼容
15 | //需要初始化一下,不然监听不到infinite事件
16 | $.init();
17 | },
18 | data : ()=>{
19 | return Value
20 | },
21 | methods: {
22 | async loadList(){
23 | try{
24 | let keyword = this.$route.params.keyword;
25 | let data = await searchLiveRoom(keyword,this.page);
26 | if(data && data.responseHeader && data.responseHeader.status == 0){
27 | let list = data.response[3].docs;
28 | let total = data.response[3].numFound;
29 | this.huyaList.total = total;
30 | setTimeout(()=>{
31 | this.showAnimation = false;
32 | },list.length * this.stagger)
33 | this.showAnimation = true;
34 | for(let i=0;i= parseInt(this.huyaList.total);
47 | }
48 | },
49 | route : {
50 | data : function(transition){
51 | let keyword = transition.to.params.keyword;
52 | this.loadList();
53 | },
54 | deactivate : function (transition) {
55 | this.huyaList = {
56 | items : [],
57 | total : 0
58 | };
59 | this.page = 1;
60 | transition.next();
61 | }
62 | }
63 | })
64 |
65 | export default Index
--------------------------------------------------------------------------------
/client/states/search/douyu/template.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
9 |
直播
10 |
11 |
12 |
13 |
14 | {{{item.title}}}
15 |
16 |
17 | {{item.nick}}
18 | {{item.person}}
19 | {{item.type}}
20 |
21 |
22 |
23 |
24 |
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 |
--------------------------------------------------------------------------------
/client/states/search/zhanqi/template.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
9 |
直播
10 |
11 |
12 |
13 |
14 | {{{item.title}}}
15 |
16 |
17 | {{item.nick}}
18 | {{item.person}}
19 | {{item.type}}
20 |
21 |
22 |
23 |
24 |
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 |
--------------------------------------------------------------------------------
/client/states/search/huya/template.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
9 |
直播
10 |
11 |
12 |
13 |
14 | {{{item.game_roomName}}}
15 |
16 |
17 | {{item.game_nick.substr(0,14)}}
18 | {{item.game_total_count}}
19 | {{item.gameName}}
20 |
21 |
22 |
23 |
24 |
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 |
--------------------------------------------------------------------------------
/client/states/search/panda/template.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
9 |
直播
10 |
11 |
12 |
13 |
14 |
15 | {{{item.name}}}
16 |
17 |
18 | {{item.nickname}}
19 | {{item.person_num}}
20 | {{item.classification}}
21 |
22 |
23 |
24 |
25 |
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 |
--------------------------------------------------------------------------------
/client/states/index/style.less:
--------------------------------------------------------------------------------
1 | .page.index{
2 | background: linear-gradient(-45deg,#76CDFF,#50E4C8,#FFD13B,#F38648,#FF290D);
3 |
4 | @cub: cubic-bezier(.73,.14,.4,1.58);
5 | svg {
6 | overflow: visible;
7 | }
8 | .search {
9 | position: absolute;
10 | top: 30%;
11 | left: 5%;
12 | //margin-left: -16rem;
13 | //margin-top: -3.5rem;
14 | width: 90%;
15 | height: 5rem;
16 |
17 | &:not(.active) {
18 | cursor: pointer;
19 | }
20 | }
21 | .search-svg {
22 | position: absolute;
23 | top: 0;
24 | left: 0;
25 | width: 100%;
26 | height: 100%;
27 |
28 | &__path {
29 | fill: none;
30 | stroke: #fff;
31 | stroke-width: 6px;
32 | }
33 | }
34 | .search-input {
35 | position: relative;
36 | width: 80%;
37 | padding: 1rem 0 0 1.5rem;
38 | background: transparent;
39 | outline: none;
40 | border: none;
41 | font-size: 2rem;
42 | color: #fff;
43 | z-index: -1;
44 | opacity: 0;
45 | transition: opacity 0.2s;
46 |
47 | &.visible {
48 | z-index: auto;
49 | opacity: 1;
50 | }
51 | }
52 | .search-close {
53 | position: absolute;
54 | top: .8rem;
55 | right: 4%;
56 | width: 2rem;
57 | height: 2rem;
58 | cursor: pointer;
59 | z-index: -1;
60 |
61 | &.visible {
62 | z-index: auto;
63 |
64 | &:before {
65 | transform: rotate(-45deg);
66 | opacity: 1;
67 | transition: transform 0.2s @cub, opacity 0.1s;
68 | }
69 | &:after {
70 | transform: rotate(45deg);
71 | opacity: 1;
72 | transition: transform 0.2s 0.2s @cub, opacity 0.1s 0.2s;
73 | }
74 | }
75 |
76 | &:before,
77 | &:after {
78 | content: "";
79 | position: absolute;
80 | top: 1.2rem;
81 | left: 0;
82 | width: 100%;
83 | height: 0.3rem;
84 | background: #fff;
85 | border-radius: 0.5rem;
86 | opacity: 0;
87 | }
88 | &:before {
89 | transform: rotate(-45deg) translateX(2rem);
90 | transition: transform 0.2s, opacity 0.1s 0.1s;
91 | }
92 | &:after {
93 | transform: rotate(45deg) translateX(2rem);
94 | transition: transform 0.2s 0.2s, opacity 0.1s 0.3s;
95 | }
96 | }
97 | }
--------------------------------------------------------------------------------
/client/states/search/bili/template.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
9 |
10 |
11 |
12 |
13 |
14 |
15 |
16 |
17 | {{{item.title}}}
18 |
19 |
20 | {{item.nick}}
21 | {{item.person}}
22 | {{item.type}}
23 |
24 |
25 |
26 |
27 |
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 |
--------------------------------------------------------------------------------
/client/states/index/route.js:
--------------------------------------------------------------------------------
1 | 'use strict';
2 | import Vue from 'vue'
3 | import Tpl from './template.html'
4 | import Value from './value'
5 | import './style.less'
6 | import Snap from '../../lib/snap.svg'
7 |
8 | let Index = Vue.extend({
9 | //replace : true, //必须注释掉 不然动画失效
10 | template : Tpl,
11 | init : function () {
12 |
13 | },
14 | ready : function(){ //做浏览器判断 和 兼容
15 | $.init();
16 | var $search = $(".search"),
17 | $input = $(".search-input"),
18 | $close = $(".search-close"),
19 | $svg = $(".search-svg"),
20 | $path = $(".search-svg__path")[0],
21 | initD = $svg.attr("data-init"),
22 | midD = $svg.attr("data-mid"),
23 | finalD = $svg.attr("data-active"),
24 | backDelay = 400,
25 | midAnim = 200,
26 | bigAnim = 400,
27 | animating = false;
28 |
29 | $(document).on("click", ".search:not(.active)", function() {
30 | if (animating) return;
31 | animating = true;
32 | $search.addClass("active");
33 |
34 | Snap($path).animate({"path": midD}, midAnim, mina.backin, function() {
35 | Snap($path).animate({"path": finalD}, bigAnim, mina.easeinout, function() {
36 | $input.addClass("visible");
37 | $input.focus();
38 | $close.addClass("visible");
39 | animating = false;
40 | });
41 | });
42 |
43 | });
44 |
45 | $(document).on("click", ".search-close", function() {
46 | if (animating) return;
47 | animating = true;
48 | $input.removeClass("visible");
49 | $close.removeClass("visible");
50 | $search.removeClass("active");
51 |
52 | setTimeout(function() {
53 | Snap($path).animate({"path": midD}, bigAnim, mina.easeinout, function() {
54 | Snap($path).animate({"path": initD}, midAnim, mina.easeinout, function() {
55 | animating = false;
56 | });
57 | });
58 | }, backDelay);
59 | });
60 |
61 | },
62 | data : ()=>{
63 | return Value
64 | },
65 | methods: {
66 |
67 | },
68 | computed : {
69 |
70 | },
71 | route : {
72 | data : function(){
73 |
74 | }
75 | }
76 | })
77 |
78 | export default Index
--------------------------------------------------------------------------------
/client/states/search/douyu/style.less:
--------------------------------------------------------------------------------
1 | .content.douyu{
2 | padding-top: .2rem;
3 | padding-bottom: 3rem;
4 |
5 | .video-box{
6 | width: 48%;
7 | margin-left: 1%;
8 | margin-right: 1%;
9 | margin-bottom: 8px;
10 | padding-bottom: 5px;
11 | position: relative;
12 | background: #fff;
13 | box-shadow: 0 0.05rem 0.1rem rgba(0, 0, 0, 0.3);
14 |
15 | .video-tag{
16 | display: inline-block;
17 | position: absolute;
18 | top: 14px;
19 | width: 50px;
20 | height: 22px;
21 | font-size: 15px;
22 | line-height: 22px;
23 | color: #fff;
24 | text-align: center;
25 | z-index: 1;
26 |
27 | &.video-tag-online{
28 | background-color: #00a0ff;
29 | }
30 | }
31 | .video-img{
32 | position: relative;
33 | width: 100%;
34 | padding-bottom: 56.8%;
35 | overflow: hidden;
36 |
37 | img{
38 | width: 100%;position: absolute;
39 | }
40 | }
41 |
42 | .video-title{
43 | max-width: 70%;
44 | padding-left: 5px;
45 | font-size: 12px;
46 | overflow: hidden;
47 | text-overflow: ellipsis;
48 | white-space: nowrap;
49 |
50 | b{
51 | color: #ff2121;
52 | }
53 | }
54 | .video-info{
55 | position: relative;
56 | font-size: 12px;
57 |
58 | .video-nickname{
59 | width: 200px;
60 | margin-left: 5px;
61 | padding-left: 12px;
62 | background: url("http://i8.pdim.gs/215adf54fcfe0cc52e924a670373eca2.png") 0 0px no-repeat;
63 | color: #787878;
64 | overflow: hidden;
65 | text-overflow: ellipsis;
66 | white-space: nowrap;
67 | }
68 | .video-number{
69 | position: absolute;
70 | padding-left: 17px;
71 | top: 0;
72 | right: 5px;
73 | background: url("http://i9.pdim.gs/5e2630d66e51d54abb59f49198fa5dd1.png") 0 3px no-repeat;
74 | color: #787878;
75 | }
76 | .video-cate{
77 | position: absolute;
78 | right: 5px;
79 | top: -17px;
80 | width: 48px;
81 | color: #00a0ff;
82 | overflow: hidden;
83 | text-align: right;
84 | //text-overflow: ellipsis;
85 | white-space: nowrap;
86 | }
87 | }
88 |
89 | .load-more{
90 | position: absolute;
91 | top: 0;
92 | left: 0;
93 | right: 0;
94 | bottom: 0;
95 | width: 100px;
96 | margin: auto;
97 | height: 30px;
98 | text-align: center;
99 | }
100 | }
101 |
102 | }
--------------------------------------------------------------------------------
/client/states/search/huya/style.less:
--------------------------------------------------------------------------------
1 | .content.huya{
2 | padding-top: .2rem;
3 | padding-bottom: 3rem;
4 |
5 | .video-box{
6 | width: 48%;
7 | margin-left: 1%;
8 | margin-right: 1%;
9 | margin-bottom: 8px;
10 | padding-bottom: 5px;
11 | position: relative;
12 | background: #fff;
13 | box-shadow: 0 0.05rem 0.1rem rgba(0, 0, 0, 0.3);
14 |
15 | .video-tag{
16 | display: inline-block;
17 | position: absolute;
18 | top: 14px;
19 | width: 50px;
20 | height: 22px;
21 | font-size: 15px;
22 | line-height: 22px;
23 | color: #fff;
24 | text-align: center;
25 | z-index: 1;
26 |
27 | &.video-tag-online{
28 | background-color: #00a0ff;
29 | }
30 | }
31 | .video-img{
32 | position: relative;
33 | width: 100%;
34 | padding-bottom: 56.8%;
35 | overflow: hidden;
36 |
37 | img{
38 | width: 100%;position: absolute;
39 | }
40 | }
41 |
42 | .video-title{
43 | max-width: 70%;
44 | padding-left: 5px;
45 | font-size: 12px;
46 | overflow: hidden;
47 | text-overflow: ellipsis;
48 | white-space: nowrap;
49 |
50 | b{
51 | color: #ff2121;
52 | }
53 | }
54 | .video-info{
55 | position: relative;
56 | font-size: 12px;
57 |
58 | .video-nickname{
59 | width: 200px;
60 | margin-left: 5px;
61 | padding-left: 12px;
62 | background: url("http://i8.pdim.gs/215adf54fcfe0cc52e924a670373eca2.png") 0 0px no-repeat;
63 | color: #787878;
64 | overflow: hidden;
65 | text-overflow: ellipsis;
66 | white-space: nowrap;
67 | }
68 | .video-number{
69 | position: absolute;
70 | padding-left: 17px;
71 | top: 0;
72 | right: 5px;
73 | background: url("http://i9.pdim.gs/5e2630d66e51d54abb59f49198fa5dd1.png") 0 3px no-repeat;
74 | color: #787878;
75 | }
76 | .video-cate{
77 | position: absolute;
78 | right: 5px;
79 | top: -17px;
80 | width: 48px;
81 | color: #00a0ff;
82 | overflow: hidden;
83 | text-align: right;
84 | //text-overflow: ellipsis;
85 | white-space: nowrap;
86 | }
87 | }
88 |
89 | .load-more{
90 | position: absolute;
91 | top: 0;
92 | left: 0;
93 | right: 0;
94 | bottom: 0;
95 | width: 100px;
96 | margin: auto;
97 | height: 30px;
98 | text-align: center;
99 | }
100 | }
101 |
102 | }
--------------------------------------------------------------------------------
/client/states/search/panda/style.less:
--------------------------------------------------------------------------------
1 | .content.panda{
2 | padding-top: .2rem;
3 | padding-bottom: 3rem;
4 |
5 | .video-box{
6 | width: 48%;
7 | margin-left: 1%;
8 | margin-right: 1%;
9 | margin-bottom: 8px;
10 | padding-bottom: 5px;
11 | position: relative;
12 | background: #fff;
13 | box-shadow: 0 0.05rem 0.1rem rgba(0, 0, 0, 0.3);
14 |
15 | .video-tag{
16 | display: inline-block;
17 | position: absolute;
18 | top: 14px;
19 | width: 50px;
20 | height: 22px;
21 | font-size: 15px;
22 | line-height: 22px;
23 | color: #fff;
24 | text-align: center;
25 | z-index: 1;
26 |
27 | &.video-tag-online{
28 | background-color: #00a0ff;
29 | }
30 | }
31 | .video-img{
32 | position: relative;
33 | width: 100%;
34 | padding-bottom: 56.8%;
35 | overflow: hidden;
36 |
37 | img{
38 | width: 100%;position: absolute;
39 | }
40 | }
41 |
42 | .video-title{
43 | max-width: 70%;
44 | padding-left: 5px;
45 | font-size: 12px;
46 | overflow: hidden;
47 | text-overflow: ellipsis;
48 | white-space: nowrap;
49 |
50 | b{
51 | color: #ff2121;
52 | }
53 | }
54 | .video-info{
55 | position: relative;
56 | font-size: 12px;
57 |
58 | .video-nickname{
59 | width: 200px;
60 | margin-left: 5px;
61 | padding-left: 12px;
62 | background: url("http://i8.pdim.gs/215adf54fcfe0cc52e924a670373eca2.png") 0 0px no-repeat;
63 | color: #787878;
64 | overflow: hidden;
65 | text-overflow: ellipsis;
66 | white-space: nowrap;
67 | }
68 | .video-number{
69 | position: absolute;
70 | padding-left: 17px;
71 | top: 0;
72 | right: 5px;
73 | background: url("http://i9.pdim.gs/5e2630d66e51d54abb59f49198fa5dd1.png") 0 3px no-repeat;
74 | color: #787878;
75 | }
76 | .video-cate{
77 | position: absolute;
78 | right: 5px;
79 | top: -17px;
80 | width: 48px;
81 | color: #00a0ff;
82 | overflow: hidden;
83 | text-align: right;
84 | //text-overflow: ellipsis;
85 | white-space: nowrap;
86 | }
87 | }
88 |
89 | .load-more{
90 | position: absolute;
91 | top: 0;
92 | left: 0;
93 | right: 0;
94 | bottom: 0;
95 | width: 100px;
96 | margin: auto;
97 | height: 30px;
98 | text-align: center;
99 | }
100 | }
101 |
102 | }
--------------------------------------------------------------------------------
/client/states/search/zhanqi/style.less:
--------------------------------------------------------------------------------
1 | .content.zhanqi{
2 | padding-top: .2rem;
3 | padding-bottom: 3rem;
4 |
5 | .video-box{
6 | width: 48%;
7 | margin-left: 1%;
8 | margin-right: 1%;
9 | margin-bottom: 8px;
10 | padding-bottom: 5px;
11 | position: relative;
12 | background: #fff;
13 | box-shadow: 0 0.05rem 0.1rem rgba(0, 0, 0, 0.3);
14 |
15 | .video-tag{
16 | display: inline-block;
17 | position: absolute;
18 | top: 14px;
19 | width: 50px;
20 | height: 22px;
21 | font-size: 15px;
22 | line-height: 22px;
23 | color: #fff;
24 | text-align: center;
25 | z-index: 1;
26 |
27 | &.video-tag-online{
28 | background-color: #00a0ff;
29 | }
30 | }
31 | .video-img{
32 | position: relative;
33 | width: 100%;
34 | padding-bottom: 56.8%;
35 | overflow: hidden;
36 |
37 | img{
38 | width: 100%;position: absolute;
39 | }
40 | }
41 |
42 | .video-title{
43 | max-width: 70%;
44 | padding-left: 5px;
45 | font-size: 12px;
46 | overflow: hidden;
47 | text-overflow: ellipsis;
48 | white-space: nowrap;
49 |
50 | b{
51 | color: #ff2121;
52 | }
53 | }
54 | .video-info{
55 | position: relative;
56 | font-size: 12px;
57 |
58 | .video-nickname{
59 | width: 200px;
60 | margin-left: 5px;
61 | padding-left: 12px;
62 | background: url("http://i8.pdim.gs/215adf54fcfe0cc52e924a670373eca2.png") 0 0px no-repeat;
63 | color: #787878;
64 | overflow: hidden;
65 | text-overflow: ellipsis;
66 | white-space: nowrap;
67 | }
68 | .video-number{
69 | position: absolute;
70 | padding-left: 17px;
71 | top: 0;
72 | right: 5px;
73 | background: url("http://i9.pdim.gs/5e2630d66e51d54abb59f49198fa5dd1.png") 0 3px no-repeat;
74 | color: #787878;
75 | }
76 | .video-cate{
77 | position: absolute;
78 | right: 5px;
79 | top: -17px;
80 | width: 48px;
81 | color: #00a0ff;
82 | overflow: hidden;
83 | text-align: right;
84 | //text-overflow: ellipsis;
85 | white-space: nowrap;
86 | }
87 | }
88 |
89 | .load-more{
90 | position: absolute;
91 | top: 0;
92 | left: 0;
93 | right: 0;
94 | bottom: 0;
95 | width: 100px;
96 | margin: auto;
97 | height: 30px;
98 | text-align: center;
99 | }
100 | }
101 |
102 | }
--------------------------------------------------------------------------------
/client/states/search/bili/style.less:
--------------------------------------------------------------------------------
1 | .content.bili{
2 | padding-top: .2rem;
3 | padding-bottom: 3rem;
4 |
5 | .video-box{
6 | width: 48%;
7 | margin-left: 1%;
8 | margin-right: 1%;
9 | margin-bottom: 8px;
10 | padding-bottom: 5px;
11 | position: relative;
12 | background: #fff;
13 | box-shadow: 0 0.05rem 0.1rem rgba(0, 0, 0, 0.3);
14 | border-radius: 4px;
15 |
16 | .video-tag{
17 | display: inline-block;
18 | position: absolute;
19 | top: 14px;
20 | width: 50px;
21 | height: 22px;
22 | font-size: 15px;
23 | line-height: 22px;
24 | color: #fff;
25 | text-align: center;
26 | z-index: 1;
27 |
28 | &.video-tag-online{
29 | background-color: #00a0ff;
30 | }
31 | }
32 | .video-img{
33 | position: relative;
34 | width: 100%;
35 | padding-bottom: 56.8%;
36 | overflow: hidden;
37 |
38 | img{
39 | width: 100%;position: absolute;
40 | border-radius: 4px 4px 0 0;
41 | }
42 | }
43 |
44 | .video-avatar{
45 | position: absolute;
46 | width: 2rem;
47 | height: 2rem;
48 | bottom: 1rem;
49 | left: .3rem;
50 | img{
51 | width: 100%;
52 | height: 100%;
53 | border-radius: 50%;
54 | border: 2px solid #fff;
55 | }
56 | }
57 | .video-title{
58 | max-width: 95%;
59 | padding-left: 30%;
60 | font-size: 12px;
61 | overflow: hidden;
62 | text-overflow: ellipsis;
63 | white-space: nowrap;
64 |
65 | b{
66 | color: #ff2121;
67 | }
68 | }
69 | .video-info{
70 | position: relative;
71 | font-size: 12px;
72 |
73 | .video-nickname{
74 | width: 200px;
75 | margin-left: 5px;
76 | padding-left: 12px;
77 | background: url("http://i8.pdim.gs/215adf54fcfe0cc52e924a670373eca2.png") 0 0px no-repeat;
78 | color: #787878;
79 | overflow: hidden;
80 | text-overflow: ellipsis;
81 | white-space: nowrap;
82 | }
83 | .video-number{
84 | position: absolute;
85 | padding-left: 17px;
86 | top: 0;
87 | right: 5px;
88 | background: url("http://i9.pdim.gs/5e2630d66e51d54abb59f49198fa5dd1.png") 0 3px no-repeat;
89 | color: #787878;
90 | }
91 | .video-cate{
92 | position: absolute;
93 | right: 5px;
94 | top: -17px;
95 | width: 48px;
96 | color: #00a0ff;
97 | overflow: hidden;
98 | text-align: right;
99 | //text-overflow: ellipsis;
100 | white-space: nowrap;
101 | }
102 | }
103 |
104 | .load-more{
105 | position: absolute;
106 | top: 0;
107 | left: 0;
108 | right: 0;
109 | bottom: 0;
110 | width: 100px;
111 | margin: auto;
112 | height: 30px;
113 | text-align: center;
114 | }
115 | }
116 |
117 | }
--------------------------------------------------------------------------------
/client/lib/cm-plugin.js:
--------------------------------------------------------------------------------
1 | 'use strict'
2 | import config from '../../env'
3 |
4 | var MyPlugin = {};
5 | MyPlugin.install = function (Vue, option) {
6 |
7 | // 设置cookie
8 | Vue.cookie = function (key, value, options) {
9 | var days, time, result, decode;
10 |
11 | if (arguments.length > 1 && String(value) !== "[object Object]") {
12 | // Enforce object
13 | options = $.extend({}, options)
14 |
15 | if (value === null || value === undefined) options.expires = -1
16 |
17 | if (typeof options.expires === 'number') {
18 | days = (options.expires * 24 * 60 * 60 * 1000)
19 | time = options.expires = new Date()
20 |
21 | time.setTime(time.getTime() + days)
22 | }
23 |
24 | value = String(value)
25 |
26 | return (document.cookie = [
27 | encodeURIComponent(key), '=',
28 | options.raw ? value : encodeURIComponent(value),
29 | options.expires ? '; expires=' + options.expires.toUTCString() : '',
30 | '; path=/',
31 | options.domain ? '; domain=' + options.domain : '',
32 | options.secure ? '; secure' : ''
33 | ].join(''))
34 | }
35 |
36 | // Key and possibly options given, get cookie
37 | options = value || {}
38 |
39 | decode = options.raw ? function (s) { return s } : decodeURIComponent
40 |
41 | return (result = new RegExp('(?:^|; )' + encodeURIComponent(key) + '=([^;]*)').exec(document.cookie)) ? decode(result[1]) : null
42 | };
43 |
44 |
45 | // 根据浏览器环境 前往登录页
46 | Vue.prototype.goLoginPage = function(_this,webapp_path){
47 | if($.device.isWeixin){
48 | window.location.href = config.formatWeixinUrl('/webapp'+webapp_path);
49 | }else{
50 | _this.$router.go('/webapp/login')
51 | }
52 | };
53 |
54 | // 根据环境去往聊天页面
55 | Vue.prototype.goChatUrl = function(_this){
56 | let userInfo = $.localStorage.getItem('webapp_userInfo');
57 | if(userInfo){
58 | _this.$router.go('/webapp/chat')
59 | }else{
60 | if($.device.isWeixin){
61 | window.location.href = config.formatWeixinUrl('/webapp/chat');
62 | }else{
63 | _this.$router.go('/webapp/login')
64 | }
65 | }
66 | };
67 |
68 | // 返回上一页
69 | Vue.prototype.goBack = function(_this){
70 | let path;
71 | try{
72 | path = _this.$router._currentTransition.from.path;
73 | if(path){
74 | window.history.back();
75 | }else{
76 | _this.$router.replace('/')
77 | }
78 | }catch (e){
79 | _this.$router.replace('/')
80 | }
81 | };
82 |
83 | // 前往路由页面
84 | Vue.prototype.goRoute = function(route,_this){
85 | _this.$router.go(route);
86 | };
87 |
88 | //是否显示顶部标题栏 在服务端设置
89 | Vue.prototype.showTopBar = window.showTopBar;
90 |
91 |
92 | // 判断设备环境
93 | let ua = navigator.userAgent;
94 | let czl_webview = ua.match(/ChezhilWebview/);
95 | Vue.prototype.czl_webview = !!czl_webview;
96 | Vue.prototype.$device = function(key){
97 | return $.device[key];
98 | };
99 |
100 | // 简单封装本地存储
101 | $.localStorage = {
102 | getItem : function(key){
103 | if (typeof localStorage === 'object') {
104 | try {
105 | return JSON.parse(localStorage.getItem(key));
106 | } catch (e) {
107 | alert('本站无痕浏览模式,请关闭后再试!');
108 | }
109 | }
110 | },
111 | setItem : function(key,value){
112 | if (typeof localStorage === 'object') {
113 | try {
114 | return localStorage.setItem(key,JSON.stringify(value));
115 | } catch (e) {
116 | alert('请关闭[无痕浏览]模式后再试!');
117 | }
118 | }
119 | },
120 | removeItem : function(key){
121 | if (typeof localStorage === 'object') {
122 | try {
123 | return localStorage.removeItem(key);
124 | } catch (e) {
125 | alert('请关闭[无痕浏览]模式后再试!');
126 | }
127 | }
128 | },
129 | getUseSize : function(){
130 | if (typeof localStorage === 'object') {
131 | try {
132 | return JSON.stringify(localStorage).length;
133 | } catch (e) {
134 | alert('请关闭[无痕浏览]模式后再试!');
135 | }
136 | }
137 | }
138 | };
139 |
140 | //保存和删除用户信息
141 | $.saveUserInfo = function(data){
142 | if(data){
143 | $.localStorage.setItem('webapp_userInfo',data);
144 | }else{
145 | $.localStorage.removeItem('webapp_userInfo');
146 | }
147 | if(data && data.car && data.car.type_id > 0){
148 | let myCar = {
149 | brand_id : data.car.brand_id,
150 | brand_name : data.car.brand_name,
151 | series_id : data.car.series_id,
152 | series_name : data.car.series_name,
153 | type_id : data.car.type_id,
154 | type_name : data.car.type_name,
155 | }
156 | $.localStorage.setItem('myCar',myCar);
157 | }else{
158 | $.localStorage.removeItem('myCar');
159 | }
160 | }
161 |
162 | //全局ajax设置
163 | $.ajaxSettings.timeout = 20e3;
164 | $.ajaxSettings.beforeSend = function(xhr,settings){
165 | xhr.setRequestHeader('Accept','application/json, text/javascript, */*; q=0.01')
166 | xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded; charset=UTF-8');
167 | }
168 | $.ajaxSettings.complete = function(xhr, status){
169 | //console.log('status=',status)
170 | if(status == 'abort'){
171 | $.toast('请求失败');
172 | }else if(status == 'timeout'){
173 | $.toast('请求超时');
174 | }else if(status == 'error'){
175 | try {
176 | let error = JSON.parse(xhr.responseText);
177 | $.toast(error.message);
178 | }catch(e){
179 | $.toast('服务器错误');
180 | }
181 | }
182 | };
183 |
184 | Date.prototype.Format = function (fmt) { //author: meizz
185 | var o = {
186 | "M+": this.getMonth() + 1, //月份
187 | "d+": this.getDate(), //日
188 | "H+": this.getHours(), //小时
189 | "m+": this.getMinutes(), //分
190 | "s+": this.getSeconds(), //秒
191 | "q+": Math.floor((this.getMonth() + 3) / 3), //季度
192 | "S": this.getMilliseconds() //毫秒
193 | };
194 | if (/(y+)/.test(fmt)) fmt = fmt.replace(RegExp.$1, (this.getFullYear() + "").substr(4 - RegExp.$1.length));
195 | for (var k in o)
196 | if (new RegExp("(" + k + ")").test(fmt)) fmt = fmt.replace(RegExp.$1, (RegExp.$1.length == 1) ? (o[k]) : (("00" + o[k]).substr(("" + o[k]).length)));
197 | return fmt;
198 | }
199 |
200 | };
201 | export default MyPlugin;
--------------------------------------------------------------------------------
/public/liveSearch/styles.3810b05e.css:
--------------------------------------------------------------------------------
1 | .video-box-transition{-webkit-transition:all .5s ease;transition:all .5s ease;-webkit-animation:bounceIn 1s .2s ease both;-moz-animation:bounceIn 1s .2s ease both}@-webkit-keyframes bounceIn{0%{opacity:0;-webkit-transform:scale(.3)}50%{opacity:1;-webkit-transform:scale(1.05)}70%{-webkit-transform:scale(.9)}to{-webkit-transform:scale(1)}}.page.index{background:-webkit-linear-gradient(135deg,#76cdff,#50e4c8,#ffd13b,#f38648,#ff290d);background:linear-gradient(-45deg,#76cdff,#50e4c8,#ffd13b,#f38648,#ff290d)}.page.index svg{overflow:visible}.page.index .search{position:absolute;top:30%;left:5%;width:90%;height:5rem}.page.index .search:not(.active){cursor:pointer}.page.index .search-svg{position:absolute;top:0;left:0;width:100%;height:100%}.page.index .search-svg__path{fill:none;stroke:#fff;stroke-width:6px}.page.index .search-input{position:relative;width:80%;padding:1rem 0 0 1.5rem;background:transparent;outline:none;border:none;font-size:2rem;color:#fff;z-index:-1;opacity:0;-webkit-transition:opacity .2s;transition:opacity .2s}.page.index .search-input.visible{z-index:auto;opacity:1}.page.index .search-close{position:absolute;top:.8rem;right:4%;width:2rem;height:2rem;cursor:pointer;z-index:-1}.page.index .search-close.visible{z-index:auto}.page.index .search-close.visible:before{-webkit-transform:rotate(-45deg);transform:rotate(-45deg);opacity:1;-webkit-transition:opacity .1s,-webkit-transform .2s cubic-bezier(.73,.14,.4,1.58);transition:opacity .1s,-webkit-transform .2s cubic-bezier(.73,.14,.4,1.58);transition:transform .2s cubic-bezier(.73,.14,.4,1.58),opacity .1s;transition:transform .2s cubic-bezier(.73,.14,.4,1.58),opacity .1s,-webkit-transform .2s cubic-bezier(.73,.14,.4,1.58)}.page.index .search-close.visible:after{-webkit-transform:rotate(45deg);transform:rotate(45deg);opacity:1;-webkit-transition:opacity .1s .2s,-webkit-transform .2s cubic-bezier(.73,.14,.4,1.58) .2s;transition:opacity .1s .2s,-webkit-transform .2s cubic-bezier(.73,.14,.4,1.58) .2s;transition:transform .2s cubic-bezier(.73,.14,.4,1.58) .2s,opacity .1s .2s;transition:transform .2s cubic-bezier(.73,.14,.4,1.58) .2s,opacity .1s .2s,-webkit-transform .2s cubic-bezier(.73,.14,.4,1.58) .2s}.page.index .search-close:after,.page.index .search-close:before{content:"";position:absolute;top:1.2rem;left:0;width:100%;height:.3rem;background:#fff;border-radius:.5rem;opacity:0}.page.index .search-close:before{-webkit-transform:rotate(-45deg) translateX(2rem);transform:rotate(-45deg) translateX(2rem);-webkit-transition:opacity .1s .1s,-webkit-transform .2s;transition:opacity .1s .1s,-webkit-transform .2s;transition:transform .2s,opacity .1s .1s;transition:transform .2s,opacity .1s .1s,-webkit-transform .2s}.page.index .search-close:after{-webkit-transform:rotate(45deg) translateX(2rem);transform:rotate(45deg) translateX(2rem);-webkit-transition:opacity .1s .3s,-webkit-transform .2s .2s;transition:opacity .1s .3s,-webkit-transform .2s .2s;transition:transform .2s .2s,opacity .1s .3s;transition:transform .2s .2s,opacity .1s .3s,-webkit-transform .2s .2s}.page.search .bar.bar-nav{top:.5rem;background:transparent}.page.search .bar.bar-nav:after{-webkit-transform:scaleY(0);transform:scaleY(0)}.page.search .bar.bar-nav .icon.icon-left{width:2.2rem;height:2.2rem;text-align:center;color:#000;background:hsla(0,0%,100%,.8);border-radius:50%}.page.search .content{top:0}.page.search .tab-item{background-size:80%;background-repeat:no-repeat;background-position:50%;-webkit-filter:grayscale(100%);-moz-filter:grayscale(100%);filter:grayscale(100%)}.page.search .tab-item span{visibility:hidden}.page.search .tab-item.panda{background-image:url("http://i5.pdim.gs/06b000f296eb5f4f2a16e9e012cfcf7e.png")}.page.search .tab-item.huya{background-image:url("http://a.dwstatic.com/huya/main/img/logo_index_new09_4217d25.png")}.page.search .tab-item.douyu{background-image:url("http://shark.douyucdn.cn/app/douyu/res/com/logo.png?20160303")}.page.search .tab-item.bili{background-image:url()}.page.search .tab-item.zhanqi{background-image:url("http://dlstatic.cdn.zhanqi.tv/assets/web/static/i/logo-6.png")}.page.search .tab-item.active{-webkit-filter:grayscale(0);-moz-filter:grayscale(0);filter:grayscale(0)}.page.search .bar.bar-tab{background-color:hsla(0,0%,100%,.9)}.content.panda{padding-top:.2rem;padding-bottom:3rem}.content.panda .video-box{width:48%;margin-left:1%;margin-right:1%;margin-bottom:8px;padding-bottom:5px;position:relative;background:#fff;box-shadow:0 .05rem .1rem rgba(0,0,0,.3)}.content.panda .video-box .video-tag{display:inline-block;position:absolute;top:14px;width:50px;height:22px;font-size:15px;line-height:22px;color:#fff;text-align:center;z-index:1}.content.panda .video-box .video-tag.video-tag-online{background-color:#00a0ff}.content.panda .video-box .video-img{position:relative;width:100%;padding-bottom:56.8%;overflow:hidden}.content.panda .video-box .video-img img{width:100%;position:absolute}.content.panda .video-box .video-title{max-width:70%;padding-left:5px;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.content.panda .video-box .video-title b{color:#ff2121}.content.panda .video-box .video-info{position:relative;font-size:12px}.content.panda .video-box .video-info .video-nickname{width:200px;margin-left:5px;padding-left:12px;background:url("http://i8.pdim.gs/215adf54fcfe0cc52e924a670373eca2.png") 0 0 no-repeat;color:#787878;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.content.panda .video-box .video-info .video-number{position:absolute;padding-left:17px;top:0;right:5px;background:url("http://i9.pdim.gs/5e2630d66e51d54abb59f49198fa5dd1.png") 0 3px no-repeat;color:#787878}.content.panda .video-box .video-info .video-cate{position:absolute;right:5px;top:-17px;width:48px;color:#00a0ff;overflow:hidden;text-align:right;white-space:nowrap}.content.panda .video-box .load-more{position:absolute;top:0;left:0;right:0;bottom:0;width:100px;margin:auto;height:30px;text-align:center}.content.huya{padding-top:.2rem;padding-bottom:3rem}.content.huya .video-box{width:48%;margin-left:1%;margin-right:1%;margin-bottom:8px;padding-bottom:5px;position:relative;background:#fff;box-shadow:0 .05rem .1rem rgba(0,0,0,.3)}.content.huya .video-box .video-tag{display:inline-block;position:absolute;top:14px;width:50px;height:22px;font-size:15px;line-height:22px;color:#fff;text-align:center;z-index:1}.content.huya .video-box .video-tag.video-tag-online{background-color:#00a0ff}.content.huya .video-box .video-img{position:relative;width:100%;padding-bottom:56.8%;overflow:hidden}.content.huya .video-box .video-img img{width:100%;position:absolute}.content.huya .video-box .video-title{max-width:70%;padding-left:5px;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.content.huya .video-box .video-title b{color:#ff2121}.content.huya .video-box .video-info{position:relative;font-size:12px}.content.huya .video-box .video-info .video-nickname{width:200px;margin-left:5px;padding-left:12px;background:url("http://i8.pdim.gs/215adf54fcfe0cc52e924a670373eca2.png") 0 0 no-repeat;color:#787878;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.content.huya .video-box .video-info .video-number{position:absolute;padding-left:17px;top:0;right:5px;background:url("http://i9.pdim.gs/5e2630d66e51d54abb59f49198fa5dd1.png") 0 3px no-repeat;color:#787878}.content.huya .video-box .video-info .video-cate{position:absolute;right:5px;top:-17px;width:48px;color:#00a0ff;overflow:hidden;text-align:right;white-space:nowrap}.content.huya .video-box .load-more{position:absolute;top:0;left:0;right:0;bottom:0;width:100px;margin:auto;height:30px;text-align:center}.content.douyu{padding-top:.2rem;padding-bottom:3rem}.content.douyu .video-box{width:48%;margin-left:1%;margin-right:1%;margin-bottom:8px;padding-bottom:5px;position:relative;background:#fff;box-shadow:0 .05rem .1rem rgba(0,0,0,.3)}.content.douyu .video-box .video-tag{display:inline-block;position:absolute;top:14px;width:50px;height:22px;font-size:15px;line-height:22px;color:#fff;text-align:center;z-index:1}.content.douyu .video-box .video-tag.video-tag-online{background-color:#00a0ff}.content.douyu .video-box .video-img{position:relative;width:100%;padding-bottom:56.8%;overflow:hidden}.content.douyu .video-box .video-img img{width:100%;position:absolute}.content.douyu .video-box .video-title{max-width:70%;padding-left:5px;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.content.douyu .video-box .video-title b{color:#ff2121}.content.douyu .video-box .video-info{position:relative;font-size:12px}.content.douyu .video-box .video-info .video-nickname{width:200px;margin-left:5px;padding-left:12px;background:url("http://i8.pdim.gs/215adf54fcfe0cc52e924a670373eca2.png") 0 0 no-repeat;color:#787878;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.content.douyu .video-box .video-info .video-number{position:absolute;padding-left:17px;top:0;right:5px;background:url("http://i9.pdim.gs/5e2630d66e51d54abb59f49198fa5dd1.png") 0 3px no-repeat;color:#787878}.content.douyu .video-box .video-info .video-cate{position:absolute;right:5px;top:-17px;width:48px;color:#00a0ff;overflow:hidden;text-align:right;white-space:nowrap}.content.douyu .video-box .load-more{position:absolute;top:0;left:0;right:0;bottom:0;width:100px;margin:auto;height:30px;text-align:center}.content.bili{padding-top:.2rem;padding-bottom:3rem}.content.bili .video-box{width:48%;margin-left:1%;margin-right:1%;margin-bottom:8px;padding-bottom:5px;position:relative;background:#fff;box-shadow:0 .05rem .1rem rgba(0,0,0,.3);border-radius:4px}.content.bili .video-box .video-tag{display:inline-block;position:absolute;top:14px;width:50px;height:22px;font-size:15px;line-height:22px;color:#fff;text-align:center;z-index:1}.content.bili .video-box .video-tag.video-tag-online{background-color:#00a0ff}.content.bili .video-box .video-img{position:relative;width:100%;padding-bottom:56.8%;overflow:hidden}.content.bili .video-box .video-img img{width:100%;position:absolute;border-radius:4px 4px 0 0}.content.bili .video-box .video-avatar{position:absolute;width:2rem;height:2rem;bottom:1rem;left:.3rem}.content.bili .video-box .video-avatar img{width:100%;height:100%;border-radius:50%;border:2px solid #fff}.content.bili .video-box .video-title{max-width:95%;padding-left:30%;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.content.bili .video-box .video-title b{color:#ff2121}.content.bili .video-box .video-info{position:relative;font-size:12px}.content.bili .video-box .video-info .video-nickname{width:200px;margin-left:5px;padding-left:12px;background:url("http://i8.pdim.gs/215adf54fcfe0cc52e924a670373eca2.png") 0 0 no-repeat;color:#787878;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.content.bili .video-box .video-info .video-number{position:absolute;padding-left:17px;top:0;right:5px;background:url("http://i9.pdim.gs/5e2630d66e51d54abb59f49198fa5dd1.png") 0 3px no-repeat;color:#787878}.content.bili .video-box .video-info .video-cate{position:absolute;right:5px;top:-17px;width:48px;color:#00a0ff;overflow:hidden;text-align:right;white-space:nowrap}.content.bili .video-box .load-more{position:absolute;top:0;left:0;right:0;bottom:0;width:100px;margin:auto;height:30px;text-align:center}.content.zhanqi{padding-top:.2rem;padding-bottom:3rem}.content.zhanqi .video-box{width:48%;margin-left:1%;margin-right:1%;margin-bottom:8px;padding-bottom:5px;position:relative;background:#fff;box-shadow:0 .05rem .1rem rgba(0,0,0,.3)}.content.zhanqi .video-box .video-tag{display:inline-block;position:absolute;top:14px;width:50px;height:22px;font-size:15px;line-height:22px;color:#fff;text-align:center;z-index:1}.content.zhanqi .video-box .video-tag.video-tag-online{background-color:#00a0ff}.content.zhanqi .video-box .video-img{position:relative;width:100%;padding-bottom:56.8%;overflow:hidden}.content.zhanqi .video-box .video-img img{width:100%;position:absolute}.content.zhanqi .video-box .video-title{max-width:70%;padding-left:5px;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.content.zhanqi .video-box .video-title b{color:#ff2121}.content.zhanqi .video-box .video-info{position:relative;font-size:12px}.content.zhanqi .video-box .video-info .video-nickname{width:200px;margin-left:5px;padding-left:12px;background:url("http://i8.pdim.gs/215adf54fcfe0cc52e924a670373eca2.png") 0 0 no-repeat;color:#787878;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.content.zhanqi .video-box .video-info .video-number{position:absolute;padding-left:17px;top:0;right:5px;background:url("http://i9.pdim.gs/5e2630d66e51d54abb59f49198fa5dd1.png") 0 3px no-repeat;color:#787878}.content.zhanqi .video-box .video-info .video-cate{position:absolute;right:5px;top:-17px;width:48px;color:#00a0ff;overflow:hidden;text-align:right;white-space:nowrap}.content.zhanqi .video-box .load-more{position:absolute;top:0;left:0;right:0;bottom:0;width:100px;margin:auto;height:30px;text-align:center}.page.video .bar.bar-nav{top:.5rem;background:transparent}.page.video .bar.bar-nav:after{-webkit-transform:scaleY(0);transform:scaleY(0)}.page.video .bar.bar-nav .icon.icon-left{width:2.2rem;height:2.2rem;text-align:center;color:#fff;background:rgba(0,0,0,.5);border-radius:50%}.page.video iframe{border:0}
2 | /*# sourceMappingURL=styles.3810b05e.css.map*/
--------------------------------------------------------------------------------