Some minor changes

This commit is contained in:
tanshu 2015-06-23 15:14:41 +05:30
parent 82313b8ec8
commit 2e2bd9df4c
9 changed files with 60 additions and 23 deletions

View File

@ -39,6 +39,7 @@ def main(global_config, **settings):
config.add_route('logout', '/logout') config.add_route('logout', '/logout')
add_route(config, 'picture', '/picture') add_route(config, 'picture', '/picture')
config.add_route('picture_raw', '/p/{id}')
config.add_route('upload', '/upload') config.add_route('upload', '/upload')
config.add_route('api_upload', '/v1/upload') config.add_route('api_upload', '/v1/upload')

View File

@ -118,6 +118,8 @@ class Picture(Base):
@classmethod @classmethod
def by_id(cls, id): def by_id(cls, id):
if not isinstance(id, uuid.UUID):
id = uuid.UUID(id)
return DBSession.query(cls).filter(cls.id == id).first() return DBSession.query(cls).filter(cls.id == id).first()
@classmethod @classmethod

View File

@ -3,7 +3,7 @@
<div class="col-sm-6 col-md-3" ng-repeat="item in info"> <div class="col-sm-6 col-md-3" ng-repeat="item in info">
<div class="thumbnail"> <div class="thumbnail">
<a href="{{item.viewUrl}}"><img <a ng-href="{{item.viewUrl}}"><img
src=""</img> src=""</img>
</a> </a>
@ -12,7 +12,7 @@
<p>{{item.description}}</p> <p>{{item.description}}</p>
<p><a class="btn" href="{{item.viewUrl}}">View <i <p><a class="btn" ng-href="{{item.viewUrl}}">View <i
class="glyphicon glyphicon-eye-open"></i></a><a class="btn" href="{{item.editUrl}}">Edit <i class="glyphicon glyphicon-eye-open"></i></a><a class="btn" href="{{item.editUrl}}">Edit <i
class="glyphicon glyphicon-edit"></i></a></p> class="glyphicon glyphicon-edit"></i></a></p>
</div> </div>

View File

@ -1,6 +1,8 @@
<div class="row"> <div class="row">
<div class="col-sm-6 col-md-3" ng-repeat="item in info.pictures"> <div class="col-sm-6 col-md-3" ng-repeat="item in info.pictures">
<div class="thumbnail"><img ng-src="{{item.url}}"/></div> <a ng-href="{{item.url}}">
<div class="thumbnail"><img ng-src="{{item.imageUrl}}"/></div>
</a>
</div> </div>
</div> </div>
<div class="row"> <div class="row">

View File

@ -32,18 +32,12 @@
controller: 'AlbumPicturesController', controller: 'AlbumPicturesController',
resolve: AlbumPicturesCtrlResolve resolve: AlbumPicturesCtrlResolve
}) })
//.when('/picture', { .when('/picture/:id', {
// templateUrl: '/app/picture/view.html', templateUrl: '/app/picture/view.html',
// controller: 'PictureController', controller: 'PictureController',
// resolve: PictureCtrl.resolve, resolve: PictureCtrlResolve,
// reloadOnSearch: false reloadOnSearch: false
//}) })
//.when('/picture/:id', {
// templateUrl: '/app/picture/view.html',
// controller: 'PictureController',
// resolve: PictureCtrl.resolve,
// reloadOnSearch: false
//})
.when('/users', { .when('/users', {
templateUrl: '/app/user/list.html', templateUrl: '/app/user/list.html',
controller: 'UserListController', controller: 'UserListController',

View File

@ -2,7 +2,8 @@
'use strict'; 'use strict';
angular.module('soter') angular.module('soter')
.controller('UploadController', ['$scope', 'Upload', UploadController]); .controller('UploadController', ['$scope', 'Upload', UploadController])
.controller('PictureController', ['$scope', 'picture', PictureController]);
function UploadController($scope, Upload) { function UploadController($scope, Upload) {
$scope.upload = function (files) { $scope.upload = function (files) {
@ -22,6 +23,19 @@
} }
}; };
} }
function PictureController($scope, picture) {
$scope.picture = picture;
}
})(); })();
var UploadCtrlResolve = {}; var UploadCtrlResolve = {};
var PictureCtrlResolve = {
album: ['$route', 'Picture', function ($route, Picture) {
var id = $route.current.params.id;
return Picture.get({id: id}).$promise;
}]
};

View File

@ -0,0 +1,5 @@
<div class="carousel-inner">
<div class="item">
<img ng-src="{{picture.imageUrl}}">
</div>
</div>

View File

@ -1,11 +1,10 @@
import uuid import uuid
import re
import pkg_resources import pkg_resources
from pyramid.response import FileResponse, Response from pyramid.response import FileResponse, Response
from pyramid.security import authenticated_userid from pyramid.security import authenticated_userid
from pyramid.view import view_config from pyramid.view import view_config
import re
import transaction import transaction
from soter.models import DBSession from soter.models import DBSession
@ -94,7 +93,8 @@ def show_pics(request):
album = Album.by_name(id) album = Album.by_name(id)
info = album_info(album) info = album_info(album)
for item in album.pictures: for item in album.pictures:
info['pictures'].append({'name': item.name, 'url': request.route_url('api_picture_id', id=item.id)}) info['pictures'].append({'name': item.name, 'url': request.route_url('picture_id', id=item.id),
'imageUrl': request.route_url('picture_raw', id=item.id)})
return info return info
@ -103,7 +103,8 @@ def album_info(id):
return {'name': "", 'description': "", 'isPublic': False, 'pictures': []} return {'name': "", 'description': "", 'isPublic': False, 'pictures': []}
if not isinstance(id, Album): if not isinstance(id, Album):
album = Album.by_id(id) album = Album.by_id(id)
else:
album = id
album = {'id': album.id, 'name': album.name, 'description': album.description, 'isPublic': album.is_public, album = {'id': album.id, 'name': album.name, 'description': album.description, 'isPublic': album.is_public,
'pictures': [], 'user': {'id': album.user_id, 'name': album.user.name}, 'pictures': [], 'user': {'id': album.user_id, 'name': album.user.name},
'isFixture': album.is_fixture} 'isFixture': album.is_fixture}

View File

@ -4,12 +4,13 @@ import uuid
import pkg_resources import pkg_resources
from pyramid.response import FileResponse from pyramid.response import FileResponse
from pyramid.security import authenticated_userid from pyramid.security import authenticated_userid
from pyramid.view import view_config from pyramid.view import view_config
import transaction import transaction
from soter.models import DBSession from soter.models import DBSession
from soter.models.master import Picture from soter.models.master import Picture
@ -37,8 +38,25 @@ def upload(request):
return {'location': file_path} return {'location': file_path}
@view_config(request_method='GET', route_name='api_picture_id', permission='Albums') @view_config(request_method='GET', route_name='picture_raw', permission='Albums')
def show_id(request): def show_raw(request):
package, resource = ('soter:upload/' + request.matchdict['id'] + '.jpg').split(':', 1) package, resource = ('soter:upload/' + request.matchdict['id'] + '.jpg').split(':', 1)
file = pkg_resources.resource_filename(package, resource) file = pkg_resources.resource_filename(package, resource)
return FileResponse(file, request=request) return FileResponse(file, request=request)
@view_config(request_method='GET', route_name='api_album_id', renderer='json', request_param='pictures',
permission='Albums')
def show_id(request):
return picture_info(request.matchdict['id'], request)
def picture_info(id, request):
if not isinstance(id, Picture):
picture = Picture.by_id(id)
else:
picture = id
album = {'id': picture.id, 'name': picture.name, 'imageUrl': request.route_url('picture_raw', id=picture.id),
'user': {'id': picture.user_id, 'name': picture.user.name}}
return album