Skip to content

Commit

Permalink
feat(all): CodeMirror updates, wordcount, and file creation
Browse files Browse the repository at this point in the history
  • Loading branch information
AntJanus committed Oct 28, 2016
1 parent 61b680a commit 9874078
Show file tree
Hide file tree
Showing 16 changed files with 158 additions and 7 deletions.
2 changes: 1 addition & 1 deletion CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ All notable changes to this project will be documented in this file. See [standa

### Features

* **browser:** CodeMirror implementation ([efac855](https://github.com/AntJanus/omen/commit/efac855))
* **browser:** CodeMirror highlighting implementation ([efac855](https://github.com/AntJanus/omen/commit/efac855))
* **version:** Standard-version and commitizen implementation ([7541885](https://github.com/AntJanus/omen/commit/7541885))


Expand Down
29 changes: 29 additions & 0 deletions app/scripts/actions/file.actions.ts
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,9 @@ export class FileActions {
static SAVING_CURRENT_FILE: string = 'SAVING_CURRENT_FILE'
static SAVED_CURRENT_FILE: string = 'SAVED_CURRENT_FILE'

static RECEIVE_NEW_FILE: string = 'RECEIVE_NEW_FILE'
static RECEIVE_DIR_FILES: string = 'RECEIVE_DIR_FILES'

static receiveAllFiles (files: any): IAction {
return {
type: FileActions.RECEIVE_ROOT_FILES,
Expand All @@ -37,6 +40,32 @@ export class FileActions {
})
}

getDirFiles (dirName): void {
this.IPCService.sendMessage('files/dir', dirName, (event, arg) => {
if (arg.id === dirName) {
this.ngRedux.dispatch({
type: FileActions.RECEIVE_DIR_FILES,
payload: {
files: arg.data
}
})
}
})
}

createFile (filePath: string): void {
this.IPCService.sendMessage('files/create', filePath, (event, arg) => {
if (arg.id === filePath) {
this.ngRedux.dispatch({
type: FileActions.RECEIVE_NEW_FILE,
payload: arg
})

return true
}
})
}

getCurrentFile (filePath: string): void {
this.IPCService.sendMessage('files/get', filePath, (event, arg) => {
if (arg.id === filePath) {
Expand Down
5 changes: 4 additions & 1 deletion app/scripts/app.module.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
import 'codemirror'
import 'codemirror/mode/gfm/gfm'
import 'codemirror/addon/display/placeholder'

import { NgModule } from '@angular/core'
import { BrowserModule } from '@angular/platform-browser'
Expand All @@ -19,6 +20,7 @@ import { AppComponent } from './app.component'
import { ContentEditorComponent } from './components/content-editor.component'
import { FileListComponent } from './components/file-list.component'
import { SidebarComponent } from './components/sidebar.component'
import { WordCountComponent } from './components/word-count.component'

@NgModule({
imports: [
Expand All @@ -31,7 +33,8 @@ import { SidebarComponent } from './components/sidebar.component'
AppComponent,
ContentEditorComponent,
FileListComponent,
SidebarComponent
SidebarComponent,
WordCountComponent
],
providers: [
IPCService,
Expand Down
7 changes: 6 additions & 1 deletion app/scripts/components/content-editor.component.ts
Original file line number Diff line number Diff line change
Expand Up @@ -13,12 +13,17 @@ export class ContentEditorComponent {
@Input()
file: IFile

content = ''

editorConfig: any = {
mode: {
name: 'gfm'
},
lineWrapping: true,
autofocus: true
scrollbarStyle: "null",
falttenSpans: true,
viewportMargin: 50,
placeholder: '-->Start here...'
}

constructor(
Expand Down
1 change: 1 addition & 0 deletions app/scripts/components/content-editor.html
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ <h2 class="content-title">
<!-- <input class="input-block" type="text" [(ngModel)]="file.title" /> -->
</h2>
<hr />
<word-count [content]="file.content"></word-count>
<codemirror [(ngModel)]="file.content" [config]="editorConfig"></codemirror>
</div>
</div>
3 changes: 2 additions & 1 deletion app/scripts/components/file-list.component.ts
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 +57,8 @@ export class FileListComponent implements OnInit {
}

createFile(file: IFile): void {
this.files.push(file)
console.log(file, 'file?')
this.fileActions.createFile(file.title)

this.newFile = {
title: '',
Expand Down
22 changes: 22 additions & 0 deletions app/scripts/components/word-count.component.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
import { Component, Input } from '@angular/core'

//untyped library
const removeMd = require('remove-markdown')

@Component({
selector: 'word-count',
templateUrl: 'scripts/components/word-count.html'
})
export class WordCountComponent {
@Input()
content: string

constructor() {}

countWords(content) {
console.log('this', content)
var plainText = removeMd(content)

return plainText.split(/[^\s]+/).length - 1
}
}
1 change: 1 addition & 0 deletions app/scripts/components/word-count.html
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
<span>{{ countWords(content) }} {{ count === 1 ? 'word' : 'words' }}</span>
4 changes: 4 additions & 0 deletions app/scripts/store/file.reducer.ts
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,10 @@ export function fileReducer (state = defaultState, action) {
return Object.assign({}, state, {
savingCurrentFile: false
})
case FileActions.RECEIVE_NEW_FILE:
return Object.assign({}, state, {
files: [...state.files, action.payload.data]
})
default:
return state
}
Expand Down
1 change: 1 addition & 0 deletions app/styles/basics/grid.less
Original file line number Diff line number Diff line change
Expand Up @@ -49,4 +49,5 @@ body {
flex: 1 1 auto;
max-width: 100%;
margin-left: 0;
overflow-y: auto;
}
4 changes: 3 additions & 1 deletion app/styles/components/content.less
Original file line number Diff line number Diff line change
@@ -1,12 +1,14 @@
.content {
max-width: 56em;
max-width: 58em;
margin: 0 auto;
padding: 1em;
box-sizing: border-box;
height: 100%;

.content-title {
margin-top: 0;
margin-bottom: 5px;
padding: 0 @content-padding;
}
}

Expand Down
2 changes: 2 additions & 0 deletions app/styles/components/sidebar.less
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,8 @@
}

.file-item {
cursor: pointer;

&:hover .file-delete {
display: inline-block;
}
Expand Down
1 change: 1 addition & 0 deletions app/styles/settings.less
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
@content-padding: 50px;
65 changes: 63 additions & 2 deletions app/styles/vendor/codemirror.less
Original file line number Diff line number Diff line change
@@ -1,13 +1,74 @@
.CodeMirror {
max-height: 100%;
height: auto;
height: inherit;
font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
}

.CodeMirror-empty .CodeMirror-lines {
color: #aeaeae;
padding: 0 @content-padding;
margin-left: -27px;
}

.CodeMirror .cm-header {
color: #000;
}

.CodeMirror-wrap .CodeMirror-line {
padding: 0 @content-padding;
}

// Headers

.cm-header-1 {
font-size: 1.4em;
}

.cm-header-2 {
font-size: 1.2em;
}

.CodeMirror-line > span > .cm-header-1:first-child {
margin-left: -21px;
}

.CodeMirror-line > span > .cm-header-2:first-child {
margin-left: -28px;
}

.CodeMirror-line > span > .cm-header-3:first-child {
margin-left: -34px;
}

//Theme override
.cm-s-default .cm-header {color: #000;}
.cm-s-default .cm-quote {color: #000;}
.cm-negative {color: #000;}
.cm-positive {color: #000;}

.cm-s-default .cm-keyword {color: #000;}
.cm-s-default .cm-atom {color: #000;}
.cm-s-default .cm-number {color: #000;}
.cm-s-default .cm-def {color: #000;}
.cm-s-default .cm-variable-2 {color: #000;}
.cm-s-default .cm-variable-3 {color: #000;}
.cm-s-default .cm-comment {color: #000;}
.cm-s-default .cm-string {color: #000;}
.cm-s-default .cm-string-2 {color: #000;}
.cm-s-default .cm-meta {color: #000;}
.cm-s-default .cm-qualifier {color: #000;}
.cm-s-default .cm-builtin {color: #000;}
.cm-s-default .cm-bracket {color: #000;}
.cm-s-default .cm-tag {color: #000;}
.cm-s-default .cm-attribute {color: #000;}
.cm-s-default .cm-hr {color: #000;}
.cm-s-default .cm-link {color: #000;}

.cm-s-default .cm-error {color: #000;}
.cm-invalidchar {color: #000;}

/* Default styles for common addons */

div.CodeMirror span.CodeMirror-matchingbracket {color: #000;}
div.CodeMirror span.CodeMirror-nonmatchingbracket {color: #000;}
.CodeMirror-matchingtag { background: rgba(255, 150, 0, .3); }
.CodeMirror-activeline-background {background: #000;}
17 changes: 17 additions & 0 deletions main/routes/fileRoutes.js
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ Promise.promisifyAll(fs)
ipcMain.on('req:files', getFiles)
ipcMain.on('req:files/get', getFile)
ipcMain.on('req:files/edit', editFile)
ipcMain.on('req:files/create', createFile)

function getFiles (event, arg) {
fs.readdirAsync(process.cwd())
Expand Down Expand Up @@ -69,3 +70,19 @@ function editFile (event, arg) {
})
})
}

function createFile (event, arg) {
var filePath = path.join(process.cwd(), arg)
fs.writeFileAsync(filePath, '')
.then(() => {
event.sender.send('res:files/create', {
id: arg,
data: {
name: arg,
title: arg,
path: arg,
isFile: true
}
})
})
}
1 change: 1 addition & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,7 @@
"ng2-redux": "^4.0.0-beta.0",
"redux": "3.6.0",
"reflect-metadata": "^0.1.8",
"remove-markdown": "0.1.0",
"rxjs": "^5.0.0-beta.12",
"zone.js": "0.6.23"
},
Expand Down

0 comments on commit 9874078

Please sign in to comment.