0.1.9 • Published 1 year ago
unplugin-code-sample v0.1.9
unplugin-code-sample
This is a unplugin for displaying code samples, support multiple packers.
Features
- Support multiple packers: Vite, Webpack, Rollup, esbuild, etc
- Automatically extract code from current page, you can also specify the source option to read the specified file
- Optionally remove code samples in production environment
- Support custom include/exclude files
Install
npm i -D unplugin-code-sampleUsage
// vite.config.js
import codeSample from "unplugin-code-sample/vite";
export default defineConfig({
  plugins: [codeSample()],
});You should put
unplugin-code-sampleplugin before other plugins that process the code.
<!-- Place the tag in the file where you want to display the source code -->
<code-sample />The plugin will encode the content of the file where the tag is located in base64, and then pass it as the data-sample-code attribute of the tag.
You can write a Vue component like this to use data:
<script setup lang="ts">
const props = defineProps<{
  dataSampleCode?: string;
}>();
const code = atob(props.dataSampleCode ?? "");
</script>
<template>
  <pre><code>{{ code }}</code></pre>
</template>React:
import React from "react";
interface CodeSampleProps {
  dataSampleCode?: string;
}
export default function CodeSample({ dataSampleCode }: CodeSampleProps) {
  const code = atob(dataSampleCode ?? "");
  return (
    <pre>
      <code>{code}</code>
    </pre>
  );
}Fold and Truncate
You can use fold and truncate to control the code sample.
<!-- fold the code between line 1 and 2, and line 5 and 7 -->
<!-- truncate the code between line 3 and 4, and line 6 and 8 -->
<code-sample fold="[[1, 2], [5, 7]]" truncate="[[3, 4], [6, 8]]" />Custom Tag Name
You can use custom tag name by setting the tagName option.
// vite.config.js
import codeSample from "unplugin-code-sample/vite";
export default defineConfig({
  plugins: [codeSample({ tagName: ["TestTag"] })],
});Specify the source path
If you don't want to display the current file, but want to specify the content of the file to be displayed, you can pass the source option to the tag, and the value is the location relative to the root directory.
<code-sample source="./hooks/useRequest.txt" />Options
export interface Options {
  /**
   * File path, support glob pattern
   *
   * @default ['**/*.vue', '**/*.jsx', '**/*.tsx', '**/*.astro', '**/*.svelte', '**/*.html']
   */
  include?: string | string[]
  exclude?: string | string[]
  /**
   * Remove the code sample in production environment
   *
   * @default false
   */
  removeInProd?: boolean
  /**
   * Custom tag name
   *
   * @default ['code-sample', 'CodeSample', 'codeSample']
   */
  tagName?: string[]
}License
MIT