Files
ulthon_information/view/admin/post/output.html

192 lines
6.3 KiB
HTML

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>{$post.title}</title>
{include file="common/_require"}
<link rel="stylesheet" href="/static/lib/prismjs/prism.css">
<script src="/static/lib/prismjs/prism.js"></script>
<link rel="stylesheet" href="/static/css/index.articles.css">
<script src="/static/lib/html2canvas/html2canvas.js"></script>
<style>
.article-body {
padding: 15px;
max-width: 715px;
}
.article-body>* {
margin: 10px 0
}
.options-box {
position: fixed;
right: 0;
top: 20%;
margin: 15px;
padding: 15px;
border-radius: 5;
border: 1px solid #e8e8e8;
background: #fff;
}
.options-box>* {
display: block;
margin-bottom: 15px;
}
.article-body.show-copyright-inner .copyright-inner {
background-color: #e8e8e8;
color: #333;
font-size: 12px;
}
</style>
</head>
<body>
<div class="article-body" id="article-body">
<h1 id="post-title">{$post.title}</h1>
<div id="post-desc">
{$post.desc}
</div>
<article id="post-content" class="ul-content">
{notempty name='$post->getData("poster")'}
<div id="post-title-img">
<img src="{$post.poster}" alt="">
</div>
{/notempty}
{$post->content_html|raw}
{:\\app\\common\\tools\\PostBlock::copyright($post)}
</article>
</div>
<div style="max-width: 715px;">
<textarea class="layui-textarea" autoHeight="true" id="post-markdown" placeholder="同步markdown内容" autocomplete="off">{$post->content_markdown|raw}</textarea>
</div>
<div class="options-box layui-btn-container">
<a class="copy-option layui-btn layui-btn-sm" target="_blank" href="{$post.read_url}">打开原文</a>
<a class="copy-option layui-btn layui-btn-sm" href="#article-body">全选</a>
<a class="copy-option layui-btn layui-btn-sm" href="#post-title">选中标题</a>
<a class="copy-option layui-btn layui-btn-sm" href="#post-desc">选中描述</a>
<a class="copy-option layui-btn layui-btn-sm select-content" href="#post-content">选中内容</a>
<div class=" layui-btn layui-btn-sm build-copyright">插入声明</div>
<div class=" layui-btn layui-btn-sm remove-copyright">删除声明</div>
<div class=" layui-btn layui-btn-sm show-copyright">显示声明</div>
<div class="layui-btn layui-btn-sm code2base64">
代码转临时图片
</div>
<div class="layui-btn layui-btn-sm resetcode">
还原代码
</div>
<a class=" layui-btn layui-btn-sm select-markdown" href="#post-markdown">选中markdown</a>
</div>
<script>
$('.code2base64').click(function () {
$('#post-content').find('pre').each(function (index, elem) {
if ($(elem).hasClass('tobase64')) {
return true;
}
$(elem).addClass('tobase64');
html2canvas(elem).then(function (canvas) {
var imgData = canvas.toDataURL("image/jpeg", 1);
$.post('{:url("File/tempBase64Save")}', {
data: imgData
}, function (result) {
var imgDom = $('<img />');
$(imgDom).attr('src', result.data.src);
$(imgDom).insertAfter(elem).addClass('pre-to-canvas')
$(elem).hide();
})
});
})
$('.resetcode').click(function () {
$('#post-content').find('.pre-to-canvas').remove();
$('#post-content').find('pre').show().each(function (index, elem) {
$(elem).removeClass('tobase64')
})
})
})
$('.copy-option').focusout(function (e) {
copyContent($(this).attr('href'))
})
$('.select-markdown').click(function () {
$('#post-markdown').select()
})
$('.build-copyright').click(function () {
var copyElem = $('.copyright').find('p').last();
var html = copyElem.html();
$('#post-content > p').not('.copyright-inner').each(function (index, elem) {
if (index > 0 && index % 8 == 0) {
if (!$(elem).next().hasClass('copyright-inner')) {
$('<blockquote>' + html + '</blockquote>').insertAfter(elem).addClass('copyright-inner')
}
}
})
})
$('.remove-copyright').click(function () {
$('.copyright-inner').remove();
})
$('.show-copyright').click(function () {
if ($('.article-body').hasClass('show-copyright-inner')) {
$('.article-body').removeClass('show-copyright-inner')
} else {
$('.article-body').addClass('show-copyright-inner')
}
})
function copyContent(id) {
var content = $(id)[0];
// 创建 Range 对象
const range = new Range();
// Range 起始位置在段落2
range.selectNode(content);
// 获取 selection 对象
const selection = window.getSelection();
selection.removeAllRanges()
// 添加光标选择的范围
selection.addRange(range);
}
$(function () {
$.fn.autoHeight = function () {
function autoHeight(elem) {
elem.style.height = 'auto';
elem.style.height = elem.scrollHeight + 20 + 'px';
}
this.each(function () {
autoHeight(this);
$(this).on('keyup', function () {
autoHeight(this);
});
});
}
$('textarea[autoHeight]').autoHeight();
})
</script>
</body>
</html>