Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Test/create folder #86

Open
wants to merge 73 commits into
base: dev
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
73 commits
Select commit Hold shift + click to select a range
f946b0b
Add style to allow word to be break and wrap
JamieHo3312 Apr 18, 2016
6230d9c
Update the style to place in the middle of the table
JamieHo3312 Apr 18, 2016
3b1c6e8
Remove angular-breadcrumb & implement breadcrumb component
Apr 21, 2016
2f1e1dc
Add base style for display property
JamieHo3312 Apr 21, 2016
d0227f2
Fix flexbox type layout issues in IE10
JamieHo3312 Apr 21, 2016
ce606a8
Add list item style for file list
JamieHo3312 Apr 21, 2016
ef3ccc9
Design file list
JamieHo3312 Apr 21, 2016
e7ad670
Change the accent theme grey to indigo
JamieHo3312 Apr 21, 2016
b17959d
Add File component
Apr 21, 2016
0a18a11
Remove angular-breadcrumb from source code
Apr 21, 2016
9ea4a82
Add click event to bucket component
Apr 22, 2016
dfb26b3
Add sample view & service to file component
Apr 22, 2016
3146d6e
Rename utils to services
Apr 25, 2016
e782e35
Move natural sotr function to utils for reusable
Apr 25, 2016
55f211c
Replace upload and create folder icon
JamieHo3312 Apr 26, 2016
dd78031
Add dialog-footer and list-dialog style
JamieHo3312 Apr 27, 2016
57bc03a
Add the ui of upload file
JamieHo3312 Apr 27, 2016
7f836dd
Real api call
May 6, 2016
745928e
Merge remote-tracking branch 'jamie/feature/design-file-list' into fe…
May 6, 2016
ad02be3
Bind controller properties to view
May 6, 2016
6fc82ff
Update $file service
May 6, 2016
635cf94
Merge branch 'dev' into feature/implement-breadcrumb
May 16, 2016
ce3cdb1
fix bug in action-navbar.html
May 16, 2016
46cf39a
Merge branch 'dev' into feature/files-list-component
May 16, 2016
b521b34
Merge branch 'feature/implement-breadcrumb' into feature/files-list-c…
May 16, 2016
6679b83
Update file module
May 16, 2016
0a58ba8
Add ng-file-upload to dependencies
May 16, 2016
a356e99
Merge remote-tracking branch 'jamie/feature/design-upload-form' into …
May 16, 2016
d11309a
Add fileUpload to vendor and remove angular-breadcrumb
May 17, 2016
6b3d4af
Add filesize filter for size format
May 17, 2016
f71b02c
Add align style for set the vertical alignment
JamieHo3312 May 17, 2016
4fc9ec7
Add style for highlight the messages
JamieHo3312 May 17, 2016
37cc662
Design transfer view
JamieHo3312 May 17, 2016
5bbc8af
Update file.html
May 18, 2016
3d1c5c6
Remove unnecessary state and dependence in file.service.js
May 18, 2016
d90dfd1
Add file upload component
May 18, 2016
0054bd7
Add sign out handler
May 18, 2016
30283b7
Add method to Upload button in action navbar
May 18, 2016
f024de0
Fix breadcrumb bar
May 18, 2016
36bc561
Merge remote-tracking branch 'jamie/feature/design-transfer' into fea…
May 18, 2016
b8f6cff
Add transfer UI & update layout component
May 18, 2016
f46b0b1
Add transfer service
May 18, 2016
cf833f4
Remove transfer import in components/index.js
May 18, 2016
c931e89
Use boolean to control upadting status
May 18, 2016
48fadf8
Move toal size method to utils
May 18, 2016
d26b84b
Update method name
May 18, 2016
89fac79
Refactor upload component
May 18, 2016
35d0104
Merge branch 'feature/files-upload-component' into feature/transfer-c…
May 18, 2016
c0a0904
Update TokenInterceptor for other error handler
May 19, 2016
c98ab5b
Complete transfer component
May 19, 2016
f5df9e0
Fix bugs of toast message
May 19, 2016
e6b383d
Add $file dependence to $transfer
May 19, 2016
891ea2d
Update transfers & properties button of action navbar
May 19, 2016
3b7d1e4
Update properties event in actions button of action navbar
May 19, 2016
c8a9133
Format the file list for handle download
May 19, 2016
dc36651
Fix bugs when response files is null
May 19, 2016
3881496
Keep the previous bucket length of breadcrumb
May 19, 2016
34c9390
Add file download method
May 19, 2016
61f2848
Fix bugs of paths property in upload service
May 19, 2016
a14c4ad
Rename folders to prefix and make it as string
May 20, 2016
b853db7
Use html5 download api to download file
May 20, 2016
cd3a9b1
Refactor file service
May 23, 2016
a3a9bde
Add error handler when the download file not exist
May 23, 2016
24dcf80
Fix bug when file size small than 1024 bytes
May 20, 2016
67bed8a
Fix bug when action navbar switch
May 20, 2016
1943d0e
Fix menu items of actions button
May 23, 2016
6598bb5
Initial the folder component
May 23, 2016
a2aa487
Add createFolder to folder service
May 23, 2016
0784947
Add folder support to file service
May 23, 2016
82eff42
Fix issue etag will be same string
May 25, 2016
3a8c75f
Merge branch 'feature/download-file-component' into feature/create-fo…
May 25, 2016
89fd0a4
The select item should be file that is downloadable
May 25, 2016
0180272
Add create folder component unit test
May 26, 2016
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Complete transfer component
Move all upload object to transfer service, because the transfer should
display upload status and delete status, so the both data must be handle
in same service.

* Move methods to transfer service
* Add some translations
* Move app's updating status to $transfer and renamed to processing
  • Loading branch information
jigsawye committed May 19, 2016
commit c98ab5bda72f6aa91ba33550fb2d92eccf7695a1
5 changes: 1 addition & 4 deletions src/components/file/upload/upload.controller.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,10 +7,7 @@ export default class FileUploadController {

$scope.$watch(
() => $upload.state,
newVal => Object.assign(this, {
...newVal,
files: newVal.files.filter(file => file.status === 'PENDING'),
})
newVal => Object.assign(this, newVal)
, true);
}

Expand Down
90 changes: 21 additions & 69 deletions src/components/file/upload/upload.servce.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,9 +5,9 @@ import FileUploadTemplate from './upload.html';

export default class FileUploadService {
/** @ngInject */
constructor(Config, Upload, $mdDialog, $file, $toast) {
constructor(Config, Upload, $mdDialog, $file, $transfer) {
Object.assign(this, {
Config, Upload, $mdDialog, $file, $toast,
Config, Upload, $mdDialog, $file, $transfer,
});

this.initState();
Expand All @@ -17,20 +17,14 @@ export default class FileUploadService {
this.state = {
files: [],
size: 0,
uploading: false,
};
}

select(selectedFiles) {
const additionalFiles = selectedFiles.filter(selectedFile =>
this.state.files.every(({ detail, status }) =>
(detail.name === selectedFile.name && status !== 'PENDING') ||
(detail.name !== selectedFile.name && status === 'PENDING')
)
this.state.files.every(({ detail }) => detail.name !== selectedFile.name)
).map(detail => ({
id: Symbol('unique id'),
status: 'PENDING',
detail,
id: Symbol('unique id'), detail,
}));

const files = [...this.state.files, ...additionalFiles];
Expand All @@ -46,34 +40,24 @@ export default class FileUploadService {
this.state = { ...this.state, files, size };
}

isUploading() {
return this.state.uploading;
}

abort() {
this.state.files.forEach(file => file.upload.abort());
this.state.files = [];
}

findFileIndex(id) {
return this.state.files.findIndex(file => file.id === id);
}

upload() {
const { bucket, folders } = this.$file.paths;
const prefix = folders.length ? '' : `${folders.join('/')}/`;
const url = `${this.Config.API_URL}/v1/file/create`;

this.state = {
uploading: true,
files: this.state.files.map(file => ({
...file,
status: 'UPLOADING',
upload: this.uploadFile(file.id, {
bucket, prefix, file: file.detail,
}, url),
})),
};
this.state.uploading = true;
this.$transfer.put(this.state.files.map(({
id, detail,
}) => ({
id,
bucket,
name: detail.name,
type: 'UPLOAD',
status: 'UPLOADING',
upload: this.uploadFile(id, {
bucket, prefix, file: detail,
}, url),
})));

this.closeDialog();
}
Expand All @@ -82,47 +66,14 @@ export default class FileUploadService {
const upload = this.Upload.upload({ url, data });

upload.then(
res => this.handleSuccess(id, res),
err => this.handleFailure(id, err),
evt => this.handleEvent(id, evt)
res => this.$transfer.handleSuccess(id, res),
err => this.$transfer.handleFailure(id, err),
evt => this.$transfer.handleEvent(id, evt)
);

return upload;
}

handleEvent(id, evt) {
const i = this.findFileIndex(id);
this.state.files[i].process = evt;
console.log(this.state.files[i].process);
console.log(this.state);
}

handleSuccess(id, res) {
const i = this.findFileIndex(id);
this.state.files[i].status = 'UPLOADED';
this.updateUpdateStatus();
this.$file.getFiles();
console.log(res);
}

handleFailure(id, err) {
const i = this.findFileIndex(id);
this.state.files[i].status = 'FAILURE';
this.updateUpdateStatus();
console.log(err);
}

removeUploadFile(id) {
const i = this.findFileIndex(id);
delete this.state.files[i];
}

updateUpdateStatus() {
this.state.uploading = this.state.files.every(
file => file.status === 'UPLOADING'
);
}

createDialog($event) {
this.$mdDialog.show({
controller: FileUploadController,
Expand All @@ -137,5 +88,6 @@ export default class FileUploadService {
closeDialog() {
this.$mdDialog.cancel();
this.state.size = 0;
this.state.files = [];
}
}
8 changes: 4 additions & 4 deletions src/components/layout/top-navbar/top-navbar.controller.js
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
export default class TopNavbarController {
/** @ngInject */
constructor($scope, $translate, $auth, $state, $toast, $mdDialog, $upload, AuthService) {
constructor($scope, $translate, $auth, $state, $toast, $mdDialog, $transfer, AuthService) {
Object.assign(this, {
$scope, $translate, $auth, $state, $toast, $mdDialog, $upload, AuthService,
$scope, $translate, $auth, $state, $toast, $mdDialog, $transfer, AuthService,
});

this.languages = [
Expand Down Expand Up @@ -32,7 +32,7 @@ export default class TopNavbarController {
* @return {void}
*/
signOut($event) {
if (this.$upload.isUploading()) {
if (this.$transfer.isProcessing()) {
this.showConfirmMessage($event).then(this.executedSignOut);
} else {
this.executedSignOut();
Expand Down Expand Up @@ -65,7 +65,7 @@ or uploads and leaving now will cancel them.Still leaving?`)
*/
executedSignOut = () => this.AuthService.signOut()
.then(() => {
this.$upload.abort();
this.$transfer.abort();
this.$auth.logout();
this.$state.go('auth.signin');
this.$toast.show('Sign Out Success!');
Expand Down
40 changes: 38 additions & 2 deletions src/components/layout/transfer/transfer.controller.js
Original file line number Diff line number Diff line change
@@ -1,12 +1,48 @@
export default class TransferController {
/** @ngInject */
constructor($layout) {
constructor($scope, $layout, $transfer) {
Object.assign(this, {
$layout,
$layout, $transfer,
});

$scope.$watch(
() => $transfer.state,
newVal => Object.assign(this, newVal)
, true);
}

toggleAutoClear() {
this.$transfer.toggleAutoClear();
}

close() {
this.$layout.toggleTransfer();
}

md2line(t) {
const status = ['FAILED', 'DELETED', 'PAUSED', 'COMPLETED'];
return status.indexOf(t.status) >= 0;
}

md3line(t) {
const status = ['UPLOADING', 'RESUMING'];
return status.indexOf(t.status) >= 0;
}

isUpload(t) {
return t.type === 'UPLOAD';
}

isDelete(t) {
return t.type === 'DELETE';
}

isUploading(t) {
return t.status === 'UPLOADING';
}

showInfo(t) {
const status = ['FAILED', 'PAUSED'];
return status.indexOf(t.status) < 0;
}
}
42 changes: 22 additions & 20 deletions src/components/layout/transfer/transfer.html
Original file line number Diff line number Diff line change
Expand Up @@ -21,57 +21,59 @@ <h2>
<md-list class="transfer-list">
<md-list-item>
<md-checkbox aria-label="Automatically clear finished transfers"
ng-model="@A.2"
ng-checked="transfer.autoClear" ng-click="transfer.toggleAutoClear()"
></md-checkbox>
<p class="md-body-1 md-accent" translate>Automatically clear finished transfers</p>
</md-list-item>

<md-list-item
ng-class="{'md-2-line':@A.3,'md-3-line':@A.4}"
ng-repeat="@A.5"
ng-class="{
'md-2-line': transfer.md2line(t),
'md-3-line': transfer.md3line(t)
}"
ng-repeat="t in transfer.transfers"
>
<md-icon
class="material-icons" ng-if="@A.6"
class="material-icons" ng-if="transfer.isUpload(t)"
>file_upload</md-icon>
<md-icon
class="material-icons" ng-if="@A.7"
class="material-icons" ng-if="transfer.isDelete(t)"
>delete</md-icon>

<div class="md-list-item-text">
<h3
class="inline-block"
translate="{{@A.8}}" translate-values="@A.9"
translate="TRANSFER.TITLE.{{ t.type }}"
translate-value-name="{{ t.name }}"
translate-value-bucket="{{ t.bucket }}"
></h3>

<div class="transfer-rate" ng-if="@A.10">
<div class="transfer-rate" ng-if="transfer.isUploading(t)">
<md-progress-linear
md-mode="determinate" value="{{@A.11}}"
md-mode="determinate" value="{{ t.process.precentage }}"
></md-progress-linear>
</div>

<p class="transfer-info">
<span ng-if="@A.12" translate="{{@A.13}}"></span>
<span
class="text-warn" ng-if="@A.14"
translate="{{@A.15}}"
></span>
<span ng-if="transfer.showInfo(t)" translate="TRANSFER.STATUS.{{ t.status }}"></span>
<span class="text-warn" ng-if="! transfer.showInfo(t)" ng-bind="t.message"></span>

<span class="transfer-loaded" ng-if="@A.10">
<span ng-bind="@A.16">1.87MB</span>
<span class="transfer-loaded" ng-if="transfer.isUploading(t)">
<span ng-bind="(t.process.loaded | filesize)"></span>
<span> / </span>
<span class="transfer-size" ng-bind="@A.17">2GB</span>
<span class="transfer-size" ng-bind="(t.process.total | filesize)"></span>
</span>

<span class="transfer-percentage" ng-if="@A.10">
<span ng-bind="@A.18"></span>
<span class="transfer-percentage" ng-if="transfer.isUploading(t)">
<span ng-bind="t.process.precentage"></span>
<span>%</span>
</span>
</p>
</div>

<md-icon
class="material-icons md-primary"
ng-if="@A.19"
ng-if="transfer.isCompleted(t)"
>check_circle</md-icon>
<!-- Those feature are not included in this sprint.
<md-icon
Expand All @@ -83,7 +85,7 @@ <h2>
ng-if="@A.21" ng-click="@A.24"
>refresh</md-icon>-->

<div class="margin-auto" ng-if="@A.22">
<div class="margin-auto" ng-if="transfer.isResuming(t)">
<md-progress-circular
class="inline-block valign-middle"
md-mode="indeterminate" md-diameter="30"
Expand Down
Loading