Skip to content

Commit

Permalink
Merge branch 'feature/docs' into develop
Browse files Browse the repository at this point in the history
  • Loading branch information
titouanmathis committed Jan 22, 2020
2 parents becde0e + bf2821b commit e21b769
Show file tree
Hide file tree
Showing 15 changed files with 9,733 additions and 6,531 deletions.
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -1,2 +1,3 @@
/node_modules
/tests/dist/
/docs/.vuepress/dist/
3 changes: 3 additions & 0 deletions docs/.vuepress/assets/scss/tailwind.config.scss
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
@tailwind base;
@tailwind components;
@tailwind utilities;
180 changes: 180 additions & 0 deletions docs/.vuepress/components/Preview.vue
Original file line number Diff line number Diff line change
@@ -0,0 +1,180 @@
<template>
<div class="preview">
<div ref="slot" v-show="false">
<slot />
</div>
<div
:style="{
height: `${iframeHeight * iframeScale}px`
}">
<div class="preview__loader" v-if="isLoading" />
<iframe
class="preview__iframe"
v-show="!isLoading"
width="100%"
:height="iframeHeight"
:srcdoc="!isFetching && html"
ref="iframe"
frameborder="0" />
</div>
</div>
</template>

<script>
import { log } from 'util';
export default {
name: 'Preview',
props: {
noResize: {
type: Boolean,
default: false,
},
},
data() {
return {
isLoading: true,
isFetching: true,
iframeHeight: 300,
styles: '',
mode: '',
}
},
computed: {
head() {
return `
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<style>
* { box-sizing: border-box; }
body { padding: 2px; overflow: hidden; }
body > div {
transform-origin: top left;
}
${this.styles}
</style>
`;
},
html() {
return `
<!DOCTYPE html>
<html>
<head>
${this.head}
</head>
<body>
${this.$refs.slot.innerHTML}
</body>
</html>
`;
},
},
watch: {
/**
* Update the iframe sizes when the iframe scale changes
*/
iframeScale() {
this.setIframeHeight();
},
},
async mounted() {
// Get the content before anything
this.styles = await this.getStyles();
this.isFetching = false;
this.$refs.iframe.addEventListener('load', () => {
this.isLoading = false;
this.setIframeHeight();
this.$refs.iframe.contentWindow.addEventListener('resize', () => {
this.setIframeHeight()
});
});
},
methods: {
/**
* Get all the styles needed for the preview
* @return {String} The CSS to be inserted in the iframe
*/
async getStyles() {
const styles = await import('!to-string-loader!css-loader!postcss-loader!sass-loader!../assets/scss/tailwind.config.scss');
return styles.default;
},
/**
* Set the iframe height and its contents scale
*/
setIframeHeight() {
this.iframeHeight = this.$refs.iframe.contentWindow.document.documentElement.getBoundingClientRect().height;
},
},
};
</script>

<style lang="css">
.preview {
position: relative;
width: 100%;
margin: 0.85rem 0;
padding: 3rem;
overflow: hidden;
background: #eee;
border-radius: 6px;
}
.preview,
.preview *,
.preview *::after,
.preview *::before {
box-sizing: border-box;
}
.preview__loader {
z-index: 1;
position: absolute;
top: 50%;
left: 50%;
display: block;
width: 20px;
height: 20px;
margin-top: -10px;
margin-left: -10px;
transform: rotate(90deg);
}
.preview__loader::before {
content: "";
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
border: 3px solid #ccc;
border-left-color: transparent;
border-radius: 50%;
animation: rotate 1s ease-in-out infinite;
}
@keyframes rotate {
from {
transform: rotate(0deg);
}
to {
transform: rotate(720deg);
}
}
.preview__iframe {
z-index: 2;
position: relative;
width: 100%;
transform-origin: top left;
}
.preview__iframe--load {
opacity: 0;
}
.preview__nav {
margin-top: 1em;
}
</style>
30 changes: 30 additions & 0 deletions docs/.vuepress/config.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
module.exports = {
title: '🔧 Tailwind CSS Config',
description: 'A custom Tailwind CSS configuration',
themeConfig: {
sidebarDepth: 2,
nav: [
{ text: 'Home', link: '/' },
{ text: 'Guide', link: '/guide/' },
{
text: 'Configuration',
link: '/configuration/',
},
{
text: 'Plugins',
link: '/plugins/',
items: [
{ text: 'Debug outline', link: '/plugins/debug-outline/' },
{ text: 'Grid', link: '/plugins/grid/' },
],
},
{ text: 'Github', link: 'https://github.com/studiometa/tailwind-config' },
],
},
postcss: {
plugins: [
require('autoprefixer'),
require('tailwindcss'),
],
},
};
3 changes: 3 additions & 0 deletions docs/.vuepress/postcss.config.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
module.exports = {
plugins: [require('tailwindcss'), require('autoprefixer')],
};
10 changes: 10 additions & 0 deletions docs/.vuepress/tailwind.config.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
const config = require('./src/index.js');

config.theme.debugOutline = true;
config.theme.colors.grey = {
'200': '#eee',
'600': '#999',
};
config.theme.colors.white = '#fff';

module.exports = config;
3 changes: 3 additions & 0 deletions docs/configuration/readme.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
# Configuration

@todo
Loading

0 comments on commit e21b769

Please sign in to comment.