Skip to content

Latest commit

 

History

History
593 lines (547 loc) · 19.4 KB

[Item]PaperNote.md

File metadata and controls

593 lines (547 loc) · 19.4 KB

[Item] PaperNote 适配Zotero 6 7 中英文文献 自用SCI笔记模版 简约清晰风格

  • MetaData : Auto extractTitle, Author, Journal, Journal Tags, Local Link, DOI, Abstract, Note Date, etc.
  • DOI : Show url if the DOI does not exist.
  • Abstract : Show abstractTranslation if the it exists. Otherwise, show abstractNote.

这个模版可以自动适配中英文文献,自动提取标题或标题翻译、作者、期刊、期刊分区、本地链接、DOI或者URL、中文摘要或英文摘要或英文摘要的翻译、笔记日期等原数据,模版样式简约清新。

期刊分区需要安装zotero-style插件,并配置期刊标签功能。标题和英文摘要的翻译需要安装zotero-pdf-translate插件。

关于此模版的一些常见问题,可以参考discussions/771

Zotero7 PaperNote Template

# Zotero7 PaperNote Template
# @author [jackhanyuan](https://github.com/jackhanyuan)
# @source [zotero-better-plugin](https://github.com/jackhanyuan/zotero-better-plugin)
# This template is specifically for importing/sharing, using better 
# notes 'import from clipboard': copy the content and
# goto Zotero menu bar, click Edit->New Template from Clipboard.  
# Do not copy-paste this to better notes template editor directly.
name: "[Item]PaperNote"
content: |-
  <!-- Title -->
  <h1 style="color:#193c47; background-color:#eef9fd; padding:8px;">
    ${(() => {
      const date = topItem.getField("date").split('T')[0];
      const title = topItem.getField("title");
      const titleTranslation = topItem.getField("titleTranslation");
      if (date && titleTranslation) {
        return `(${date}) ${title} (${titleTranslation})`;
      } else if (date) {
        return `(${date}) ${title}`;
      } else {
        return `${title}`;
      }
    })()}
  </h1>
  
  <!-- Meta Data -->
  <table>
    <!-- Author -->
    <tr>
      <td style="color:#193c47; background-color:#dbeedd; padding:8px;">
        <b>Author:</b> ${topItem.getCreators().slice(0, 10).map((v) => v.firstName + " " + v.lastName).join("; ") + (topItem.getCreators().length > 10 ? "; et al." : ";")}
      </td>
    </tr>
  
    <!-- Journal -->
    <tr>
      <td style="color:#193c47; background-color:#f3faf4; padding:8px;">
        <b style="color:#193c47;">Journal: 
        <b style="color:#FF0000">
          ${topItem.getField('publicationTitle')},
        </b>
        ${(()=>{
          const volume = topItem.getField('volume');
          const issue = topItem.getField('issue');
          const pages = topItem.getField('pages');
          const year = topItem.getField('date').split('-')[0];
          let line = "";
          if (volume) {
            line += volume;
            if (issue) {
              line += '(' + issue + ')';
              line += pages ? ": " + pages + "," : ","
            } else {
              line += pages ? ": " + pages + "," : ","
            }
          } else if (issue) {
            line += '(' + issue + ')';
            line += pages ? ": " + pages : ","
          } else {
            line += pages ? pages + "," : ""
          }
          line += year ? " " + year + "." : ""; 
          return line;
        })()}
        </b>
      </td>
    </tr>
  
    <!-- Journal Tags -->
    <tr>
      <td style="color:#193c47; background-color:#dbeedd; padding:8px;">
        <b>Journal Tags: </b>
        <!-- In Zotero7, the tags of Ethereal Style plugin are referenced. Please install Ethereal Style in advance. -->
        ${{
        let space = " ㅤㅤ ㅤㅤ"
        return Array.prototype.map.call(
          Zotero.ZoteroStyle.api.renderCell(topItem, "publicationTags").childNodes,
          e => {
            e.innerText =  space + e.innerText + space;
            return e.outerHTML
          }
          ).join(space)
        }}$
      </td>
    </tr>
  
    <!-- Local Link -->
    <tr>
      <td style="color:#193c47; background-color:#f3faf4; padding:8px;">
        ${(() => {
          const attachments = Zotero.Items.get(topItem.getAttachments());
          const pdf = attachments.filter((i) => i.isPDFAttachment());
          if (pdf && pdf.length > 0) {
            return `<b>Local Link: </b><a href="zotero://open-pdf/0_${pdf[0].key}">${pdf[0].getFilename()}</a>`;
          } else if (attachments && attachments.length > 0) {
            return `<b>Local Link: </b><a href="zotero://open-pdf/0_${attachments[0].key}">${attachments[0].getFilename()}</a>`;
          } else {
            return `<b>Local Link: </b>`;
          }
        })()}
      </td>
    </tr>
    
    <!-- DOI or URL -->
    <tr>
      <td style="color:#193c47; background-color:#dbeedd; padding:8px;">
        ${(() => {
          const doi = topItem.getField("DOI");
          if (doi) {
            return `<b>DOI: </b><a href="https://doi.org/${topItem.getField('DOI')}">${topItem.getField('DOI')}</a>`;
          } else {
            return `<b>URL: </b><a href="${topItem.getField('url')}">${topItem.getField('url')}</a>`;
          }
        })()}
      </td>
    </tr>
    
    <!-- Abstract -->
    <tr>
      <td style="color:#193c47; background-color:#f3faf4; padding:8px;">
        ${(() => {
          const abstractTranslation = topItem.getField('abstractTranslation');
          if (abstractTranslation) {
            return `<b>Abstract Translation: </b><i>${abstractTranslation}</i>`;
          } else {
            return `<b>Abstract: </b><i>${topItem.getField('abstractNote')}</i>`;
          }
        })()}
      </td>
    </tr>
    
    <!-- Tags -->
    <tr>
    <td style="color:#193c47; background-color:#dbeedd; padding:8px;">
      <!-- Filter and display tags starting with # -->
      <b>Tags:</b> ${topItem.getTags().map(tagObj => tagObj.tag.startsWith('#') ? tagObj.tag + ' ,':'').join(' ') || ''}
    </td>
    </tr>
  
    <!-- Note Date -->
    <tr>
      <td style="color:#193c47; background-color:#f3faf4; padding:8px;">
        <b>Note Date: </b>${new Date().toLocaleString()}
      </td>
    </tr>
  
  </table>
  
  <!-- Main Content -->
  <span>
    <h2 style="color:#e0ffff; background-color:#66cdaa;">📜 Research Core</h2>
    <hr />
  </span>
  <blockquote>Tips: What was done, what problem was solved, innovations and shortcomings?</blockquote>
  <p></p>
  <h3>⚙️ Content</h3>
  <p></p>
  <h3>💡 Innovations</h3>
  <p></p>
  <h3>🧩 Shortcomings</h3>
  <p></p>
  
  <span>
    <h2 style="color:#20b2aa; background-color:#afeeee;">🔁 Research Content</h2>
    <hr />
  </span>
  <p></p>
  <h3>💧 Data</h3>
  <p></p>
  <h3>👩🏻‍💻 Method</h3>
  <p></p>
  <h3>🔬 Experiment</h3>
  <p></p>
  <h3>📜 Conclusion</h3>
  <p></p>
  
  <span>
    <h2 style="color:#004d99; background-color:#87cefa;">🤔 Personal Summary</h2>
    <hr />
  </span>
  <blockquote>Tips: What aspects did you question, how do you think it can be improved?</blockquote>
  <p></p>
  <h3>🙋‍♀️ Key Records</h3>
  <p></p>
  <h3>📌 To be resolved</h3>
  <p></p>
  <h3>💭 Thought Inspiration</h3>
  <p></p>

Zotero7 PaperNote Template 中文版本在下面,仅仅把文字替换成了中文

# Zotero7 PaperNote Template (Chinese)
# @author [jackhanyuan](https://github.com/jackhanyuan)
# @source [zotero-better-plugin](https://github.com/jackhanyuan/zotero-better-plugin)
# This template is specifically for importing/sharing, using better 
# notes 'import from clipboard': copy the content and
# goto Zotero menu bar, click Edit->New Template from Clipboard.  
# Do not copy-paste this to better notes template editor directly.
name: "[Item]论文笔记"
content: |-
  <!-- 标题 -->
  <h1 style="color:#193c47; background-color:#eef9fd; padding:8px;">
    ${(() => {
      const date = topItem.getField("date").split('T')[0];
      const title = topItem.getField("title");
      const titleTranslation = topItem.getField("titleTranslation");
      if (date && titleTranslation) {
        return `(${date}) ${title} (${titleTranslation})`;
      } else if (date) {
        return `(${date}) ${title}`;
      } else {
        return `${title}`;
      }
    })()}
  </h1>
  
  <!-- Meta Data -->
  <table>
    <!-- 作者 -->
    <tr>
      <td style="color:#193c47; background-color:#dbeedd; padding:8px;">
        <b>作者:</b> ${topItem.getCreators().slice(0, 10).map((v) => v.firstName + " " + v.lastName).join("; ") + (topItem.getCreators().length > 10 ? "; et al." : ";")}
      </td>
    </tr>
  
    <!-- 期刊 -->
    <tr>
      <td style="color:#193c47; background-color:#f3faf4; padding:8px;">
        <b style="color:#193c47;">期刊: 
        <b style="color:#FF0000">
          ${topItem.getField('publicationTitle')},
        </b>
        ${(()=>{
          const volume = topItem.getField('volume');
          const issue = topItem.getField('issue');
          const pages = topItem.getField('pages');
          const year = topItem.getField('date').split('-')[0];
          let line = "";
          if (volume) {
            line += volume;
            if (issue) {
              line += '(' + issue + ')';
              line += pages ? ": " + pages + "," : ","
            } else {
              line += pages ? ": " + pages + "," : ","
            }
          } else if (issue) {
            line += '(' + issue + ')';
            line += pages ? ": " + pages : ","
          } else {
            line += pages ? pages + "," : ""
          }
          line += year ? " " + year + "." : ""; 
          return line;
        })()}
        </b>
      </td>
    </tr>
  
    <!-- 期刊分区 -->
    <tr>
      <td style="color:#193c47; background-color:#dbeedd; padding:8px;">
        <b>期刊分区: </b>
        <!-- Zotero7中,引用了Ethereal Style插件的标签,请提前安装Ethereal Style-->
        ${{
        let space = " ㅤㅤ ㅤㅤ"
        return Array.prototype.map.call(
          Zotero.ZoteroStyle.api.renderCell(topItem, "publicationTags").childNodes,
          e => {
            e.innerText =  space + e.innerText + space;
            return e.outerHTML
          }
          ).join(space)
        }}$
      </td>
    </tr>

    <!-- 本地链接 -->
    <tr>
      <td style="color:#193c47; background-color:#f3faf4; padding:8px;">
        ${(() => {
          const attachments = Zotero.Items.get(topItem.getAttachments());
          const pdf = attachments.filter((i) => i.isPDFAttachment());
          if (pdf && pdf.length > 0) {
            return `<b>本地链接: </b><a href="zotero://open-pdf/0_${pdf[0].key}">${pdf[0].getFilename()}</a>`;
          } else if (attachments && attachments.length > 0) {
            return `<b>本地链接: </b><a href="zotero://open-pdf/0_${attachments[0].key}">${attachments[0].getFilename()}</a>`;
          } else {
            return `<b>本地链接: </b>`;
          }
        })()}
      </td>
    </tr>

    <!-- DOI or URL -->
    <tr>
      <td style="color:#193c47; background-color:#dbeedd; padding:8px;">
        ${(() => {
          const doi = topItem.getField("DOI");
          if (doi) {
            return `<b>DOI: </b><a href="https://doi.org/${topItem.getField('DOI')}">${topItem.getField('DOI')}</a>`;
          } else {
            return `<b>URL: </b><a href="${topItem.getField('url')}">${topItem.getField('url')}</a>`;
          }
        })()}
      </td>
    </tr>
    
    <!-- 摘要 -->
    <tr>
      <td style="color:#193c47; background-color:#f3faf4; padding:8px;">
        ${(() => {
          const abstractTranslation = topItem.getField('abstractTranslation');
          if (abstractTranslation) {
            return `<b>摘要翻译: </b><i>${abstractTranslation}</i>`;
          } else {
            return `<b>摘要: </b><i>${topItem.getField('abstractNote')}</i>`;
          }
        })()}
      </td>
    </tr>

    <!-- 标签 -->
    <tr>
    <td style="color:#193c47; background-color:#dbeedd; padding:8px;">
      <!-- 仅过滤并显示#开头的标签 -->
      <b>标签:</b> ${topItem.getTags().map(tagObj => tagObj.tag.startsWith('#') ? tagObj.tag + ' ,':'').join(' ') || ''}
    </td>
    </tr>
  
    <!-- 笔记日期 -->
    <tr>
      <td style="color:#193c47; background-color:#f3faf4; padding:8px;">
        <b>笔记日期: </b>${new Date().toLocaleString()}
      </td>
    </tr>
  
  </table>
  
  <!-- 正文 -->
  <span>
    <h2 style="color:#e0ffff; background-color:#66cdaa;">📜 研究核心</h2>
    <hr />
  </span>
  <blockquote>Tips: 做了什么,解决了什么问题,创新点与不足?</blockquote>
  <p></p>
  <h3>⚙️ 内容</h3>
  <p></p>
  <h3>💡 创新点</h3>
  <p></p>
  <h3>🧩 不足</h3>
  <p></p>
  
  <span>
    <h2 style="color:#20b2aa; background-color:#afeeee;">🔁 研究内容</h2>
    <hr />
  </span>
  <p></p>
  <h3>💧 数据</h3>
  <p></p>
  <h3>👩🏻‍💻 方法</h3>
  <p></p>
  <h3>🔬 实验</h3>
  <p></p>
  <h3>📜 结论</h3>
  <p></p>
  
  <span>
    <h2 style="color:#004d99; background-color:#87cefa;">🤔 个人总结</h2>
    <hr />
  </span>
  <blockquote>Tips: 你对哪些内容产生了疑问,你认为可以如何改进?</blockquote>
  <p></p>
  <h3>🙋‍♀️ 重点记录</h3>
  <p></p>
  <h3>📌 待解决</h3>
  <p></p>
  <h3>💭 思考启发</h3>
  <p></p>

Zotero6 PaperNote Template

# Zotero6 PaperNote Template (Chinese)
# @author [jackhanyuan](https://github.com/jackhanyuan)
# @source [zotero-better-plugin](https://github.com/jackhanyuan/zotero-better-plugin)
# This template is specifically for importing/sharing, using better 
# notes 'import from clipboard': copy the content and
# goto Zotero menu bar, click Edit->New Template from Clipboard.  
# Do not copy-paste this to better notes template editor directly.
name: "[Item]论文笔记"
content: |-
  <!-- 标题 -->
  <h1 style="color:#193c47; background-color:#eef9fd; padding:8px;">
    ${(() => {
      const date = topItem.getField("date").split('T')[0];
      const title = topItem.getField("title");
      const titleTranslation = topItem.getField("titleTranslation");
      if (date && titleTranslation) {
        return `(${date}) ${title} (${titleTranslation})`;
      } else if (date) {
        return `(${date}) ${title}`;
      } else {
        return `${title}`;
      }
    })()}
  </h1>
  
  <!-- Meta Data -->
  <table>
    <!-- 作者 -->
    <tr>
      <td style="color:#193c47; background-color:#dbeedd; padding:8px;">
        <b>作者:</b> ${topItem.getCreators().slice(0, 10).map((v) => v.firstName + " " + v.lastName).join("; ") + (topItem.getCreators().length > 10 ? "; et al." : ";")}
      </td>
    </tr>
  
    <!-- 期刊 -->
    <tr>
      <td style="color:#193c47; background-color:#f3faf4; padding:8px;">
        <b style="color:#193c47;">期刊: 
        <b style="color:#FF0000">
          ${topItem.getField('publicationTitle')},
        </b>
        ${(()=>{
          const volume = topItem.getField('volume');
          const issue = topItem.getField('issue');
          const pages = topItem.getField('pages');
          const year = topItem.getField('date').split('-')[0];
          let line = "";
          if (volume) {
            line += volume;
            if (issue) {
              line += '(' + issue + ')';
              line += pages ? ": " + pages + "," : ","
            } else {
              line += pages ? ": " + pages + "," : ","
            }
          } else if (issue) {
            line += '(' + issue + ')';
            line += pages ? ": " + pages : ","
          } else {
            line += pages ? pages + "," : ""
          }
          line += year ? " " + year + "." : ""; 
          return line;
        })()}
        </b>
      </td>
    </tr>
  
    <!-- 期刊分区 -->
    <tr>
      <td style="color:#193c47; background-color:#dbeedd; padding:8px;">
        <b>期刊分区: </b>
        <!-- 引用了zotero style插件的标签,请提前安装,否则找不到分区 -->
        ${(() => {let space = " ㅤㅤ ㅤㅤ"
                return Array.prototype.map.call(Zotero.ZoteroStyle.data.ztoolkit.ItemTree.globalCache.renderCellHooks.PublicationTags(
            0,
            Zotero.ZoteroStyle.data.ztoolkit.ItemTree.fieldHooks.globalCache.getFieldHooks.PublicationTags(
            "", true, true,
            topItem, undefined)
            ).childNodes,
            e => {
            e.innerText = space + space + e.innerText + space + space;
            return e.outerHTML
            }).join(space)
            })()
            }
      </td>
    </tr>

    <!-- 本地链接 -->
    <tr>
      <td style="color:#193c47; background-color:#f3faf4; padding:8px;">
        ${(() => {
          const attachments = Zotero.Items.get(topItem.getAttachments());
          const pdf = attachments.filter((i) => i.isPDFAttachment());
          if (pdf && pdf.length > 0) {
            return `<b>本地链接: </b><a href="zotero://open-pdf/0_${pdf[0].key}">${pdf[0].getFilename()}</a>`;
          } else if (attachments && attachments.length > 0) {
            return `<b>本地链接: </b><a href="zotero://open-pdf/0_${attachments[0].key}">${attachments[0].getFilename()}</a>`;
          } else {
            return `<b>本地链接: </b>`;
          }
        })()}
      </td>
    </tr>
    
    <!-- DOI or URL -->
    <tr>
      <td style="color:#193c47; background-color:#dbeedd; padding:8px;">
        ${(() => {
          const doi = topItem.getField("DOI");
          if (doi) {
            return `<b>DOI: </b><a href="https://doi.org/${topItem.getField('DOI')}">${topItem.getField('DOI')}</a>`;
          } else {
            return `<b>URL: </b><a href="${topItem.getField('url')}">${topItem.getField('url')}</a>`;
          }
        })()}
      </td>
    </tr>
    
    <!-- 摘要 -->
    <tr>
      <td style="color:#193c47; background-color:#f3faf4; padding:8px;">
        ${(() => {
          const abstractTranslation = topItem.getField('abstractTranslation');
          if (abstractTranslation) {
            return `<b>摘要翻译: </b><i>${abstractTranslation}</i>`;
          } else {
            return `<b>摘要: </b><i>${topItem.getField('abstractNote')}</i>`;
          }
        })()}
      </td>
    </tr>

    <!-- 标签 -->
    <tr>
    <td style="color:#193c47; background-color:#dbeedd; padding:8px;">
      <!-- 仅过滤并显示#开头的标签 -->
      <b>标签:</b> ${topItem.getTags().map(tagObj => tagObj.tag.startsWith('#') ? tagObj.tag + ' ,':'').join(' ') || ''}
    </td>
    </tr>
  
    <!-- 笔记日期 -->
    <tr>
      <td style="color:#193c47; background-color:#f3faf4; padding:8px;">
        <b>笔记日期: </b>${new Date().toLocaleString()}
      </td>
    </tr>
  
  </table>
  
  <!-- 正文 -->
  <span>
    <h2 style="color:#e0ffff; background-color:#66cdaa;">📜 研究核心</h2>
    <hr />
  </span>
  <blockquote>Tips: 做了什么,解决了什么问题,创新点与不足?</blockquote>
  <p></p>
  <h3>⚙️ 内容</h3>
  <p></p>
  <h3>💡 创新点</h3>
  <p></p>
  <h3>🧩 不足</h3>
  <p></p>
  
  <span>
    <h2 style="color:#20b2aa; background-color:#afeeee;">🔁 研究内容</h2>
    <hr />
  </span>
  <p></p>
  <h3>💧 数据</h3>
  <p></p>
  <h3>👩🏻‍💻 方法</h3>
  <p></p>
  <h3>🔬 实验</h3>
  <p></p>
  <h3>📜 结论</h3>
  <p></p>
  
  <span>
    <h2 style="color:#004d99; background-color:#87cefa;">🤔 个人总结</h2>
    <hr />
  </span>
  <blockquote>Tips: 你对哪些内容产生了疑问,你认为可以如何改进?</blockquote>
  <p></p>
  <h3>🙋‍♀️ 重点记录</h3>
  <p></p>
  <h3>📌 待解决</h3>
  <p></p>
  <h3>💭 思考启发</h3>
  <p></p>