125 lines
4.6 KiB
Handlebars
125 lines
4.6 KiB
Handlebars
<section class="gh-canvas">
|
|
<header class="gh-canvas-header">
|
|
<h2 class="gh-canvas-title">Your stories</h2>
|
|
<section class="view-actions">
|
|
{{#link-to "editor.new" class="gh-btn gh-btn-green" data-test-new-post-button=true}}<span>New story</span>{{/link-to}}
|
|
</section>
|
|
</header>
|
|
<div class="gh-contentfilter">
|
|
<div class="gh-contentfilter-left">
|
|
{{#power-select
|
|
selected=selectedType
|
|
options=availableTypes
|
|
searchEnabled=false
|
|
onchange=(action "changeType")
|
|
tagName="div"
|
|
classNames="gh-contentfilter-menu gh-contentfilter-type"
|
|
triggerClass="gh-contentfilter-menu-trigger"
|
|
dropdownClass="gh-contentfilter-menu-dropdown"
|
|
matchTriggerWidth=false
|
|
data-test-type-select=true
|
|
as |type|
|
|
}}
|
|
{{type.name}}
|
|
{{/power-select}}
|
|
|
|
{{#unless session.user.isAuthor}}
|
|
{{#power-select
|
|
selected=selectedAuthor
|
|
options=availableAuthors
|
|
searchField="name"
|
|
onchange=(action "changeAuthor")
|
|
tagName="div"
|
|
classNames="gh-contentfilter-menu gh-contentfilter-author"
|
|
triggerClass="gh-contentfilter-menu-trigger"
|
|
dropdownClass="gh-contentfilter-menu-dropdown"
|
|
searchPlaceholder="Search authors"
|
|
matchTriggerWidth=false
|
|
data-test-author-select=true
|
|
as |author|
|
|
}}
|
|
{{author.name}}
|
|
{{/power-select}}
|
|
{{/unless}}
|
|
|
|
{{#power-select
|
|
selected=selectedTag
|
|
options=availableTags
|
|
searchField="name"
|
|
onchange=(action "changeTag")
|
|
tagName="div"
|
|
classNames="gh-contentfilter-menu gh-contentfilter-tag"
|
|
triggerClass="gh-contentfilter-menu-trigger"
|
|
dropdownClass="gh-contentfilter-menu-dropdown"
|
|
searchPlaceholder="Search tags"
|
|
matchTriggerWidth=false
|
|
data-test-tag-select=true
|
|
as |tag|
|
|
}}
|
|
{{tag.name}}
|
|
{{/power-select}}
|
|
</div>
|
|
|
|
<div class="gh-contentfilter-right">
|
|
Sort by:
|
|
{{#power-select
|
|
selected=selectedOrder
|
|
options=availableOrders
|
|
searchEnabled=false
|
|
onchange=(action "changeOrder")
|
|
tagName="div"
|
|
classNames="gh-contentfilter-menu gh-contentfilter-sort"
|
|
triggerClass="gh-contentfilter-menu-trigger"
|
|
dropdownClass="gh-contentfilter-menu-dropdown"
|
|
horizontalPosition="right"
|
|
matchTriggerWidth=false
|
|
data-test-order-select=true
|
|
as |order|
|
|
}}
|
|
{{order.name}}
|
|
{{/power-select}}
|
|
</div>
|
|
</div>
|
|
|
|
<section class="content-list">
|
|
<ol class="posts-list">
|
|
{{#each model as |post|}}
|
|
{{gh-posts-list-item
|
|
post=post
|
|
active=(eq post selectedPost)
|
|
onDoubleClick="openEditor"
|
|
data-test-post-id=post.id}}
|
|
{{else}}
|
|
<li class="no-posts-box">
|
|
<div class="no-posts">
|
|
{{#if showingAll}}
|
|
<h3>You Haven't Written Any Posts Yet!</h3>
|
|
{{#link-to "editor.new"}}<button type="button" class="gh-btn gh-btn-green gh-btn-lg"><span>Write a new Post</span></button>{{/link-to}}
|
|
{{else}}
|
|
<h3>No posts match the current filter</h3>
|
|
{{#link-to "posts.index" (query-params type=null)}}<button type="button" class="gh-btn gh-btn-lg"><span>Show all posts</span></button>{{/link-to}}
|
|
{{/if}}
|
|
</div>
|
|
</li>
|
|
{{/each}}
|
|
</ol>
|
|
|
|
{{infinity-loader
|
|
infinityModel=model
|
|
scrollable=".gh-main"
|
|
triggerOffset=1000}}
|
|
</section>
|
|
|
|
{{#if showDeletePostModal}}
|
|
{{gh-fullscreen-modal "delete-post"
|
|
model=(hash
|
|
post=selectedPost
|
|
onSuccess=(route-action 'onPostDeletion')
|
|
)
|
|
close=(action "toggleDeletePostModal")
|
|
modifier="action wide"}}
|
|
{{/if}}
|
|
|
|
{{outlet}}
|
|
</section>
|