283 lines
13 KiB
Go HTML Template
283 lines
13 KiB
Go HTML Template
<div {{if .ReadmeInList}}id="readme" {{end}}class="{{TabSizeClass .Editorconfig .FileName}} non-diff-file-content">
|
|
{{- if .FileError}}
|
|
<div class="ui error message">
|
|
<div class="text left tw-whitespace-pre">{{.FileError}}</div>
|
|
</div>
|
|
{{end}}
|
|
{{- if .FileWarning}}
|
|
<div class="ui warning message">
|
|
<div class="text left tw-whitespace-pre">{{.FileWarning}}</div>
|
|
</div>
|
|
{{end}}
|
|
|
|
{{if not .ReadmeInList}}
|
|
<div id="repo-file-commit-box" class="ui segment list-header tw-mb-4 tw-flex tw-justify-between">
|
|
<div class="latest-commit">
|
|
{{template "repo/latest_commit" .}}
|
|
</div>
|
|
{{if .LatestCommit}}
|
|
{{if .LatestCommit.Committer}}
|
|
<div class="text grey age">
|
|
{{TimeSince .LatestCommit.Committer.When ctx.Locale}}
|
|
</div>
|
|
{{end}}
|
|
{{end}}
|
|
</div>
|
|
{{end}}
|
|
|
|
<h4 class="file-header ui top attached header tw-flex tw-items-center tw-justify-between tw-flex-wrap">
|
|
<div class="file-header-left tw-flex tw-items-center tw-py-2 tw-pr-4">
|
|
{{if .ReadmeInList}}
|
|
{{svg "octicon-book" 16 "tw-mr-2"}}
|
|
<strong><a class="default-link muted" href="#readme">{{.FileName}}</a></strong>
|
|
{{else}}
|
|
{{template "repo/file_info" .}}
|
|
{{end}}
|
|
</div>
|
|
<div class="file-header-right file-actions tw-flex tw-items-center tw-flex-wrap">
|
|
{{if .HasSourceRenderedToggle}}
|
|
<div class="ui compact icon buttons">
|
|
<a href="?display=source" class="ui mini basic button {{if .IsDisplayingSource}}active{{end}}" data-tooltip-content="{{ctx.Locale.Tr "repo.file_view_source"}}">{{svg "octicon-code" 15}}</a>
|
|
<a href="{{$.Link}}" class="ui mini basic button {{if .IsDisplayingRendered}}active{{end}}" data-tooltip-content="{{ctx.Locale.Tr "repo.file_view_rendered"}}">{{svg "octicon-file" 15}}</a>
|
|
</div>
|
|
{{end}}
|
|
{{if not .ReadmeInList}}
|
|
<div class="ui buttons tw-mr-1">
|
|
{{if .SymlinkURL}}
|
|
<a class="ui mini basic button" href="{{$.SymlinkURL}}" data-kind="follow-symlink">{{ctx.Locale.Tr "repo.file_follow"}}</a>
|
|
{{end}}
|
|
<a class="ui mini basic button" href="{{$.RawFileLink}}">{{ctx.Locale.Tr "repo.file_raw"}}</a>
|
|
{{if not .IsViewCommit}}
|
|
<a class="ui mini basic button" href="{{.RepoLink}}/src/commit/{{PathEscape .CommitID}}/{{PathEscapeSegments .TreePath}}">{{ctx.Locale.Tr "repo.file_permalink"}}</a>
|
|
{{end}}
|
|
{{if .IsRepresentableAsText}}
|
|
<a class="ui mini basic button" href="{{.RepoLink}}/blame/{{.BranchNameSubURL}}/{{PathEscapeSegments .TreePath}}">{{ctx.Locale.Tr "repo.blame"}}</a>
|
|
{{end}}
|
|
<a class="ui mini basic button" href="{{.RepoLink}}/commits/{{.BranchNameSubURL}}/{{PathEscapeSegments .TreePath}}">{{ctx.Locale.Tr "repo.file_history"}}</a>
|
|
{{if .EscapeStatus.Escaped}}
|
|
<button class="ui mini basic button unescape-button tw-hidden">{{ctx.Locale.Tr "repo.unescape_control_characters"}}</button>
|
|
<button class="ui mini basic button escape-button">{{ctx.Locale.Tr "repo.escape_control_characters"}}</button>
|
|
{{end}}
|
|
</div>
|
|
<a download href="{{$.RawFileLink}}"><span class="btn-octicon" data-tooltip-content="{{ctx.Locale.Tr "repo.download_file"}}">{{svg "octicon-download"}}</span></a>
|
|
<a id="copy-content" class="btn-octicon {{if not .CanCopyContent}} disabled{{end}}"{{if or .IsImageFile (and .HasSourceRenderedToggle (not .IsDisplayingSource))}} data-link="{{$.RawFileLink}}"{{end}} data-tooltip-content="{{if .CanCopyContent}}{{ctx.Locale.Tr "copy_content"}}{{else}}{{ctx.Locale.Tr "copy_type_unsupported"}}{{end}}">{{svg "octicon-copy" 14}}</a>
|
|
{{if .EnableFeed}}
|
|
{{if .IsViewBranch}}
|
|
<a class="btn-octicon" href="{{$.FeedURL}}/rss/{{$.BranchNameSubURL}}/{{PathEscapeSegments .TreePath}}" data-tooltip-content="{{ctx.Locale.Tr "rss_feed"}}">
|
|
{{svg "octicon-rss" 14}}
|
|
</a>
|
|
{{else}}
|
|
<span class="btn-octicon disabled" data-tooltip-content="{{ctx.Locale.Tr "repo.rss.must_be_on_branch"}}">
|
|
{{svg "octicon-rss" 14}}
|
|
</span>
|
|
{{end}}
|
|
{{end}}
|
|
{{if .Repository.CanEnableEditor}}
|
|
{{if .CanEditFile}}
|
|
<a href="{{.RepoLink}}/_edit/{{PathEscapeSegments .BranchName}}/{{PathEscapeSegments .TreePath}}"><span class="btn-octicon" data-tooltip-content="{{.EditFileTooltip}}">{{svg "octicon-pencil"}}</span></a>
|
|
{{else}}
|
|
<span class="btn-octicon disabled" data-tooltip-content="{{.EditFileTooltip}}">{{svg "octicon-pencil"}}</span>
|
|
{{end}}
|
|
{{if .CanDeleteFile}}
|
|
<a href="{{.RepoLink}}/_delete/{{PathEscapeSegments .BranchName}}/{{PathEscapeSegments .TreePath}}"><span class="btn-octicon btn-octicon-danger" data-tooltip-content="{{.DeleteFileTooltip}}">{{svg "octicon-trash"}}</span></a>
|
|
{{else}}
|
|
<span class="btn-octicon disabled" data-tooltip-content="{{.DeleteFileTooltip}}">{{svg "octicon-trash"}}</span>
|
|
{{end}}
|
|
{{end}}
|
|
{{else if .EscapeStatus.Escaped}}
|
|
<button class="ui mini basic button unescape-button tw-mr-1 tw-hidden">{{ctx.Locale.Tr "repo.unescape_control_characters"}}</button>
|
|
<button class="ui mini basic button escape-button tw-mr-1">{{ctx.Locale.Tr "repo.escape_control_characters"}}</button>
|
|
{{end}}
|
|
{{if and .ReadmeInList .CanEditReadmeFile}}
|
|
<a class="btn-octicon" data-tooltip-content="{{ctx.Locale.Tr "repo.editor.edit_this_file"}}" href="{{.RepoLink}}/_edit/{{PathEscapeSegments .BranchName}}/{{PathEscapeSegments .TreePath}}/{{PathEscapeSegments .FileName}}">{{svg "octicon-pencil"}}</a>
|
|
{{end}}
|
|
<a class="btn-octicon" data-tooltip-content="{{ctx.Locale.Tr "repo.editor.edit_this_file"}}" href="{{.RepoLink}}/_run/{{PathEscapeSegments .BranchName}}/{{PathEscapeSegments .TreePath}}/{{PathEscapeSegments .FileName}}">{{svg "octicon-paper-airplane"}}</a>
|
|
</div>
|
|
</h4>
|
|
<div class="ui bottom attached table unstackable segment">
|
|
{{if not (or .IsMarkup .IsRenderedHTML)}}
|
|
{{template "repo/unicode_escape_prompt" dict "EscapeStatus" .EscapeStatus "root" $}}
|
|
{{end}}
|
|
<div class="file-view{{if .IsMarkup}} markup {{.MarkupType}}{{else if .IsPlainText}} plain-text{{else if .IsTextSource}} code-view{{end}}">
|
|
{{if .IsMarkup}}
|
|
{{if .FileContent}}{{.FileContent}}{{end}}
|
|
{{else if .IsPlainText}}
|
|
<pre>{{if .FileContent}}{{.FileContent}}{{end}}</pre>
|
|
{{else if not .IsTextSource}}
|
|
<div class="view-raw">
|
|
{{if .IsImageFile}}
|
|
<img src="{{$.RawFileLink}}">
|
|
{{else if .IsVideoFile}}
|
|
<video controls src="{{$.RawFileLink}}">
|
|
<strong>{{ctx.Locale.Tr "repo.video_not_supported_in_browser"}}</strong>
|
|
</video>
|
|
{{else if .IsAudioFile}}
|
|
<audio controls src="{{$.RawFileLink}}">
|
|
<strong>{{ctx.Locale.Tr "repo.audio_not_supported_in_browser"}}</strong>
|
|
</audio>
|
|
{{else if .IsPDFFile}}
|
|
<div class="pdf-content is-loading" data-src="{{$.RawFileLink}}" data-fallback-button-text="{{ctx.Locale.Tr "repo.diff.view_file"}}"></div>
|
|
{{else if .IsIFC}}
|
|
|
|
|
|
<div class="full-screen" id="container" style="width: 100%;height:500px;"></div>
|
|
<script type="module">
|
|
|
|
import * as THREE from "https://unpkg.com/three@0.152.2/build/three.module.js";
|
|
import * as OBC from "/assets/js/openbim-components.js";
|
|
import * as WEBIFC from "https://unpkg.com/web-ifc@0.0.50/web-ifc-api.js";
|
|
import Stats from "https://unpkg.com/stats-js@1.0.1/src/Stats.js";
|
|
import * as dat from "https://unpkg.com/three@0.152.2/examples/jsm/libs/lil-gui.module.min.js";
|
|
import {downloadZip} from "https://unpkg.com/client-zip@2.3.0/index.js";
|
|
|
|
const container = document.getElementById('container');
|
|
const components = new OBC.Components();
|
|
|
|
components.scene = new OBC.SimpleScene(components);
|
|
components.renderer = new OBC.PostproductionRenderer(components, container);
|
|
components.camera = new OBC.SimpleCamera(components);
|
|
components.raycaster = new OBC.SimpleRaycaster(components);
|
|
|
|
components.init();
|
|
|
|
components.renderer.postproduction.enabled = true;
|
|
const scene = components.scene.get();
|
|
components.camera.controls.setLookAt(12, 6, 8, 0, 0, -10);
|
|
components.scene.setup();
|
|
|
|
const grid = new OBC.SimpleGrid(components, new THREE.Color(0x666666));
|
|
const customEffects = components.renderer.postproduction.customEffects;
|
|
customEffects.excludedMeshes.push(grid.get());
|
|
|
|
let fragments = new OBC.FragmentManager(components);
|
|
let fragmentIfcLoader = new OBC.FragmentIfcLoader(components);
|
|
|
|
const mainToolbar = new OBC.Toolbar(components, { name: 'Main Toolbar', position: 'bottom' });
|
|
components.ui.addToolbar(mainToolbar);
|
|
const ifcButton = fragmentIfcLoader.uiElement.get("main");
|
|
mainToolbar.addChild(ifcButton);
|
|
|
|
await fragmentIfcLoader.setup()
|
|
|
|
const excludedCats = [
|
|
WEBIFC.IFCTENDONANCHOR,
|
|
WEBIFC.IFCREINFORCINGBAR,
|
|
WEBIFC.IFCREINFORCINGELEMENT,
|
|
];
|
|
|
|
for(const cat of excludedCats) {
|
|
fragmentIfcLoader.settings.excludedCategories.add(cat);
|
|
}
|
|
|
|
fragmentIfcLoader.settings.webIfc.COORDINATE_TO_ORIGIN = true;
|
|
fragmentIfcLoader.settings.webIfc.OPTIMIZE_PROFILES = true;
|
|
|
|
async function loadIfcAsFragments() {
|
|
//const testpath="http://localhost:3014/rvba/test/src/branch/main/1019-column.ifc"
|
|
//const testpath="/rvba/test/src/branch/main/1019-column.ifc"
|
|
//const testpath="http://localhost:3014/rvba/test/raw/branch/main/1019-column.ifc"
|
|
const testpath="{{$.RawFileLink}}"
|
|
//const testpath="http://localhost:3014/rvba/test/src/branch/main/example.ifc"
|
|
//const file = await fetch('./small.ifc');
|
|
const file = await fetch(testpath);
|
|
const data = await file.arrayBuffer();
|
|
const buffer = new Uint8Array(data);
|
|
const model = await fragmentIfcLoader.load(buffer, "example");
|
|
scene.add(model);
|
|
}
|
|
|
|
async function exportFragments() {
|
|
if (!fragments.groups.length) return;
|
|
const group = fragments.groups[0];
|
|
const data = fragments.export(group);
|
|
const blob = new Blob([data]);
|
|
const fragmentFile = new File([blob], 'small.frag');
|
|
|
|
const files = [];
|
|
files.push(fragmentFile);
|
|
files.push(new File([JSON.stringify(group.properties)], 'small.json'));
|
|
const result = await downloadZip(files).blob();
|
|
result.name = 'example';
|
|
download(result);
|
|
}
|
|
|
|
function download(file) {
|
|
const link = document.createElement('a');
|
|
link.href = URL.createObjectURL(file);
|
|
link.download = file.name;
|
|
document.body.appendChild(link);
|
|
link.click();
|
|
link.remove();
|
|
}
|
|
|
|
function disposeFragments() {
|
|
fragments.dispose();
|
|
}
|
|
|
|
const stats = new Stats();
|
|
stats.showPanel(2);
|
|
document.body.append(stats.dom);
|
|
stats.dom.style.left = '0px';
|
|
const renderer = components.renderer;
|
|
renderer.onBeforeUpdate.add(() => stats.begin());
|
|
renderer.onAfterUpdate.add(() => stats.end());
|
|
|
|
window.dispatchEvent(new Event('resize'));
|
|
|
|
const settings = {
|
|
loadFragments: () => loadIfcAsFragments(),
|
|
exportFragments: () => exportFragments(),
|
|
disposeFragments: () => disposeFragments(),
|
|
};
|
|
|
|
const gui = new dat.GUI();
|
|
|
|
//gui.add(settings, 'loadFragments').name('Import fragments');
|
|
//gui.add(settings, 'exportFragments').name('Export fragments');
|
|
//gui.add(settings, 'disposeFragments').name('Dispose fragments');
|
|
|
|
loadIfcAsFragments();
|
|
|
|
</script>
|
|
|
|
|
|
{{else}}
|
|
<a href="{{$.RawFileLink}}" rel="nofollow">{{ctx.Locale.Tr "repo.file_view_raw"}}</a>
|
|
{{end}}
|
|
</div>
|
|
{{else if .FileSize}}
|
|
{{if .IsFileTooLarge}}
|
|
<table>
|
|
<tbody>
|
|
<tr>
|
|
<td><strong>{{ctx.Locale.Tr "repo.file_too_large"}}</strong></td>
|
|
</tr>
|
|
</tbody>
|
|
</table>
|
|
{{else}}
|
|
<table>
|
|
<tbody>
|
|
{{range $idx, $code := .FileContent}}
|
|
{{$line := Eval $idx "+" 1}}
|
|
<tr>
|
|
<td id="L{{$line}}" class="lines-num"><span id="L{{$line}}" data-line-number="{{$line}}"></span></td>
|
|
{{if $.EscapeStatus.Escaped}}
|
|
<td class="lines-escape">{{if (index $.LineEscapeStatus $idx).Escaped}}<button class="toggle-escape-button btn interact-bg" title="{{if (index $.LineEscapeStatus $idx).HasInvisible}}{{ctx.Locale.Tr "repo.invisible_runes_line"}} {{end}}{{if (index $.LineEscapeStatus $idx).HasAmbiguous}}{{ctx.Locale.Tr "repo.ambiguous_runes_line"}}{{end}}"></button>{{end}}</td>
|
|
{{end}}
|
|
<td rel="L{{$line}}" class="lines-code chroma"><code class="code-inner">{{$code}}</code></td>
|
|
</tr>
|
|
{{end}}
|
|
</tbody>
|
|
</table>
|
|
<div class="code-line-menu tippy-target">
|
|
{{if $.Permission.CanRead $.UnitTypeIssues}}
|
|
<a class="item ref-in-new-issue" role="menuitem" data-url-issue-new="{{.RepoLink}}/issues/new" data-url-param-body-link="{{.Repository.Link}}/src/commit/{{PathEscape .CommitID}}/{{PathEscapeSegments .TreePath}}{{if $.HasSourceRenderedToggle}}?display=source{{end}}" rel="nofollow noindex">{{ctx.Locale.Tr "repo.issues.context.reference_issue"}}</a>
|
|
{{end}}
|
|
<a class="item view_git_blame" role="menuitem" href="{{.Repository.Link}}/blame/commit/{{PathEscape .CommitID}}/{{PathEscapeSegments .TreePath}}">{{ctx.Locale.Tr "repo.view_git_blame"}}</a>
|
|
<a class="item copy-line-permalink" role="menuitem" data-url="{{.Repository.Link}}/src/commit/{{PathEscape .CommitID}}/{{PathEscapeSegments .TreePath}}{{if $.HasSourceRenderedToggle}}?display=source{{end}}">{{ctx.Locale.Tr "repo.file_copy_permalink"}}</a>
|
|
</div>
|
|
{{end}}
|
|
{{end}}
|
|
</div>
|
|
</div>
|
|
</div>
|